注: このプロジェクトは、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の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
>>: Linuxはlsofコマンドを使用してファイルのオープンステータスを確認します
個人アカウントのパスワードを変更する一般ユーザーが個人アカウントのパスワードを変更する場合は、他のコ...
1. parseFloat() 関数Web ページ上に簡単な計算機を作成し、テキスト ボックスに ...
誤って source.list の内容を変更し、一連のエラーが発生した場合は、デフォルトのソース フ...
React は、開発者が Web およびモバイルベースのアプリケーションを作成するために使用するオ...
inode番号でファイルを削除するまずls -iを使用して、削除するファイルのinode番号を見つけ...
MySQLの概要MySQL はリレーショナル データベース管理システムです。データベースは構造化され...
目次1. 仮想マシンをダウンロードする2. 仮想マシンのインストールVMware のダウンロードとイ...
目次1. はじめに: 2. プロトタイプチェーン継承: 3. コンストラクタ継承の借用(オブジェクト...
[問題の説明]私たちの実稼働環境には、複数の MySQL サーバー (MySQL 5.6.21) の...
Linux/Mac の MySQL パスワードを忘れた場合はどうすればいいですか?心配しないでくださ...
仕事では、docker や kubernetes などのオープンソース ツールをさらに活用しましょう...
最初のタイプ: 完全な CSS コントロール、レイヤーフローティング (ログインページに適しています...
フォームを作成するときに、名前、携帯電話番号、出生地などの 2 つのフィールドを揃える状況に遭遇する...
1. 概要MySQL バージョン: 5.6.21ダウンロードアドレス: https://dev.my...
目次1. 需要1. 需要2. SDKパラメータ設定1. ディレクトリ構造3. コードの実装1. バッ...