WeChat公式アカウントでReactプロジェクトを実行する方法

WeChat公式アカウントでReactプロジェクトを実行する方法

注: このプロジェクトは、create-react-app と antd-mobile を組み合わせて作成された H5 であり、WeChat 公式アカウントで実行されます。

1. a タグを使用して PDF をプレビューまたはダウンロードします。書き方は、携帯電話でクリックしても反応がなく、パソコンでクリックするとウェブページがクラッシュする、というものです。

<a href='pdf または画像パス'>
  PDF または画像名</a>

理由は、ブラウザが安全でないアクセスを検出し、ブロックしたためです。したがって、エラー プロンプトに従って、2 つの新しい属性 target と rel を追加し、次のように記述します。

<a href='pdf または画像パス' target='_blank' rel="noreferrer">
  PDF または画像名</a>

パソコンでもiOSでも正常に閲覧できます。

ただし、Android ではいくつかの状況があります。

a) 携帯電話には QQ ブラウザが搭載されており、PDF を直接開くことができます。 (通常のプレビューです)

b) 携帯電話に QQ ブラウザがインストールされていないが、他のブラウザがインストールされている場合は、QQ ブラウザをダウンロードするか、他のブラウザで開くように求めるボックスが表示されます。 (これも通常のプレビューダウンロードです)

c) 携帯電話には QQ ブラウザはありませんが、他のブラウザはあります。PDF ファイルをクリックすると、読み込みバーが表示されますが、その後プレビューやプロンプトは表示されません。 (これは異常であり、WeChat によって禁止されています) a タグにダウンロード属性を追加すると、効果 b) が発生する可能性があります。

<a href='pdf または画像パス' target='_blank' rel="noreferrer" ダウンロード>
  PDF または画像名</a>

また、PDFを直接プレビューする必要がある場合は、 react-pdf-js プラグインを使用できます。欠点は、PDFファイルが少し大きい場合、読み込みと表示が非常に遅くなることです。そのため、上記の方法をお勧めします。

2. antd-mobile の長いリストの listView を使用して長いリストを読み込みます。 (モバイルデバイス上の長いリストに対する代替ソリューションを提供します)

3. プロジェクト開始当初、実行した途端に babel プラグインが不足しているというさまざまな問題が報告されました。原因を突き止めるのに 2 時間以上かかりました。webpack 設定ファイルでは、plugins にさらに 2 つのプラグインが設定されていましたが、この 2 つのプラグインはプロジェクトにインストールされておらず、必要ありませんでした。そのため、設定から削除して再度実行したところ、エラーは発生しませんでした。

4. Echartsは地図と棒グラフを描画します

a) 中国の地図を描く

v5 以降では、マップアウトラインデータは提供されません。バージョン v4.9.0 を使用する利点は、マップアウトラインデータがあり、マップ上の州名も中央揃えになることです。マップ上のフローティングレイヤーはツールチップで設定します。特に位置を追加する必要はありません。デフォルトの表示位置は柔軟です。

b) 縦棒グラフを描く

v4 バージョンには並べ替え API がありません。縦棒グラフのデータを並べ替える必要がある場合は、バックエンドの同僚と通信して、データを並べ替えて返すように依頼してください。誤解が生じた場合は、ここでソート関数を記述して対処できます。

5. useRef を使用して値をバインドし、DOM に直接バインドできる操作を実行します。

バックエンドシステムを書く場合、通常はUIコンポーネントを直接導入します。しかし、モバイル側のUIには要件があり、UIライブラリにコンポーネントを導入してスタイルを変更するのも面倒です。入力タグを例に挙げます。

UI ライブラリの Input コンポーネントは双方向バインディングを簡単に実現できますが、独自のスタイルを持っているため、入力ボックスのスタイルをデザイナーが描画したものと同じに保つのは困難です。

ネイティブ HTML タグ - 入力。スタイルをカスタマイズできますが、双方向バインディングはありません。たとえば、ログインページでは、アカウントのパスワードを入力する必要があります。js を使用してアカウントのパスワードを取得できますが、自分で多くのコードを記述する必要があります。現時点では、useRef の方が適しています。useState や useEffect と同様に、これは react のフック関数です。次のように使用します。

import { useState,useRef } from 'react'; //はじめに
const inputRef = useRef<any>(); //const [phone, setPhone] = useState(""); を定義します。
​
エクスポートデフォルトconstLogin=()=> {
  定数changePhone = () => {
    setPhone(inputRef?.current?.value)
  }
    戻る (
       /*入力タグにバインド*/
       <input value={phone} ref={inputRef} onChange={changePhone} maxLength={11} placeholder='電話番号を入力してください' />
        )
}

6. コンポーネントをパッケージするための小さなアイデア

単一責任の原則: コンポーネントは 1 つのことだけを実行する必要があります。コンポーネントが複雑になった場合は、小さなコンポーネントに分割します。

上記は、ReactプロジェクトがWeChat公式アカウントで実行される方法の詳細な内容です。WeChat公式アカウントでのReactの実行の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • Amap を使用した React 実装例 (react-amap)
  • Reactの仮想DOMとdiffアルゴリズムの詳細な説明
  • ファイルのアップロードの進行状況を示す React の例
  • React で遅延読み込みを使用して最初の画面の読み込み時間を短縮する方法
  • ReactでCSSをエレガントに書く方法
  • 最も単純な ErrorBoundary コンポーネントをカプセル化して、React 例外を処理する
  • React Fiber構造の作成手順
  • React の 3 つの主要属性における Ref の使用に関する詳細な説明
  • Reactのようなフレームワークをゼロから作成する
  • React useEffect の理解と使用

<<:  MySQL準備原理の詳細な説明

>>:  Linuxはlsofコマンドを使用してファイルのオープンステータスを確認します

推薦する

MySQL スレーブ ライブラリ Seconds_Behind_Master 遅延の概要

目次MySQL スレーブ ライブラリ Seconds_Behind_Master 遅延の概要1. 遅...

ローカル写真をアップロードする前にプレビューコード例を実装するための HTML5 と jQuery

HTML5 と jQuery はアップロード前にローカル画像のプレビューを実装しており、その効果は...

Linux での grep コマンドの使い方の詳細な説明

1. 公式紹介grep は Linux でよく使用されるコマンドです。これは、ファイルやテキストに対...

カルーセルアニメーションを実現するVueコンポーネント

この記事では、カルーセルアニメーションを実現するためのVueコンポーネントの具体的なコードを例として...

Windows と Linux 間のリモート デスクトップ接続

Linux へのリモート デスクトップ接続といえば、まず VNC の使用を思い浮かべるかもしれません...

NodeJS は画像テキスト分割を実現します

この記事では、画像テキストセグメンテーションを実装するためのNodeJSの具体的なコードを参考までに...

tomcat+nginx を使用してマルチアプリケーション デプロイメントを実装するためのサンプル コード

目次マルチアプリケーションの展開1-Tomcat 構成1.1- プロジェクト構成1.2-サービス構成...

CSS と JS を使用して下線効果を実装する方法の例

この記事では、主に 2 種類の下線の動的効果について説明します。1 つ目は、ホバーすると X 軸が内...

Dockerでnginxをデプロイし、設定ファイルを変更する方法

Dockerでnginxをデプロイするのはとても簡単ですたった 1 行のコマンド: docker 実...

Mysql データベース ストアド プロシージャの基本構文の説明

プロシージャ sp_name を削除します//これまで、MYSQL 構文の基礎知識について説明して...

Hタグはウェブページ制作において適切に使用すべきである

HTML タグには、ページのタイトルを処理するための特別なタグがあります。これらは h1、h2、h3...

MySQL の日付と時刻関数の概要 (MySQL 5.X)

1. MySQLは現在の日付と時刻を取得する関数1.1 現在の日付 + 時刻 (日付 + 時刻) ...

他の人が私のウェブページを保存したり、サイトをコピーしたりするのを防ぐためのヒント

現在、インターネット上でウェブサイトをコピーすることは非常に一般的です。では、他人が私たちのウェブサ...

ウェブページサイズに関する調査

<br />統計によると、Web ページの平均サイズは 2003 年以降 3 倍に増加し...

Vue 仮想 DOM クイックスタート

目次仮想DOM仮想DOMとは何か仮想DOMの役割Vue の仮想 DOM vノードvNodeとはvNo...