" を通じて画像を読み取ります。 2. "require('~/images/2.png').default" メソッドを使用して画像を読み取ります。 3. img フィールドをファイル名と画像名の 2 つの部分に分割し、"require('@/assets)" を使用します。 「読む方法」 そのまま受け取ってください。"/> " を通じて画像を読み取ります。 2. "require('~/images/2.png').default" メソッドを使用して画像を読み取ります。 3. img フィールドをファイル名と画像名の 2 つの部分に分割し、"require('@/assets)" を使用します。 「読む方法」 そのまま受け取ってください。">

ホームページ  >  記事  >  ウェブフロントエンド  >  反応使用は必要ですか?

反応使用は必要ですか?

藏色散人
藏色散人オリジナル
2022-12-27 09:47:543449ブラウズ

react では require を使用できます。正しい使用方法は次のとおりです: 1. "反応使用は必要ですか?

反応使用は必要ですか?import user from &#39;../img/user.png&#39; <img src={user} alt="" />1.2%20%E6%96%B9%E6%B3%95%202

2%20%E7%95%AA%E7%9B%AE%E3%81%AE%E6%96%B9%E6%B3%95%E3%82%82%E3%80%81%E3%82%88%E3%82%8A%E4%B8%80%E8%88%AC%E7%9A%84%E3%81%AB%E4%BD%BF%E7%94%A8%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%E5%BD%93%E6%99%82%E3%80%81%E3%83%AD%E3%83%BC%E3%82%AB%E3%83%AB%20%E3%82%A4%E3%83%A1%E3%83%BC%E3%82%B8%E3%82%92%E8%AA%AD%E3%81%BF%E5%8F%96%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%20require%20%E3%83%A1%E3%82%BD%E3%83%83%E3%83%89%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%99%E3%82%8B%E3%81%A8%E3%80%81%E3%82%A8%E3%83%A9%E3%83%BC%E3%81%8C%E7%99%BA%E7%94%9F%E3%81%99%E3%82%8B%E5%8F%AF%E8%83%BD%E6%80%A7%E3%81%8C%E9%AB%98%E3%81%8F%E3%81%AA%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%81%93%E3%81%A7%E3%81%AF%E3%80%81%E6%AC%A1%E3%81%AE%E6%96%B9%E6%B3%95%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%E5%9B%B3%E3%81%AE%E3%83%A1%E3%82%BD%E3%83%83%E3%83%89%E3%81%AF%E6%AC%A1%E3%81%AE%E3%81%A8%E3%81%8A%E3%82%8A%E3%81%A7%E3%81%99:%20

<img src={require(&#39;../img/icon1.png&#39;)} alt="" />

%E8%A3%9C%E8%B6%B3%E6%96%87:%20require%20%E3%81%AB%E3%81%AF%E6%96%87%E5%AD%97%E5%88%97%E3%81%AE%E3%81%BF%E3%82%92%E8%A8%98%E8%BF%B0%E3%81%A7%E3%81%8D%E3%80%81%E5%A4%89%E6%95%B0%E3%81%AF%E8%A8%98%E8%BF%B0%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%20

2.%20require%20%E3%81%A7%E7%94%BB%E5%83%8F%E3%82%92%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%82%81%E3%81%AA%E3%81%84%E5%A0%B4%E5%90%88%E3%81%AE%E8%A7%A3%E6%B1%BA%E7%AD%96%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6

2.1%20%E3%82%B1%E3%83%BC%E3%82%B9%201

%E6%96%B9%E6%B3%95%202%20%E3%81%A7%E7%94%BB%E5%83%8F%E3%82%92%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%82%80%E3%81%93%E3%81%A8%E3%81%8C%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E7%94%BB%E5%83%8F%E3%82%92%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%82%80%E3%81%93%E3%81%A8%E3%81%8C%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%E5%AE%9F%E8%A1%8C%E6%99%82%E3%81%AB%E3%83%AD%E3%83%BC%E3%83%89%E3%81%95%E3%82%8C%E3%82%8B%20%E3%82%A4%E3%83%A1%E3%83%BC%E3%82%B8%E3%82%92%E3%83%AD%E3%83%BC%E3%83%89%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%81%AE%E5%95%8F%E9%A1%8C%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%E3%80%81%E3%82%AA%E3%83%B3%E3%83%A9%E3%82%A4%E3%83%B3%E3%81%A7%202%20%E3%81%A4%E3%81%AE%E8%A7%A3%E6%B1%BA%E7%AD%96%E3%82%92%E8%A6%8B%E3%81%A4%E3%81%91%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%E6%9C%80%E5%88%9D%E3%81%AE%E8%A7%A3%E6%B1%BA%E7%AD%96%E3%81%AF%E6%AC%A1%E3%81%AE%E3%81%A8%E3%81%8A%E3%82%8A%E3%81%A7%E3%81%99:%20%E3%81%9F%E3%81%A0%E3%81%97%E3%80%81" file-loader loader : esmodule true false>

{
  test: /.(png|jpg|gif|jpeg)$/,
  use: [{
  loader: &#39;url-loader&#39;,
  // loader: &#39;file-loader&#39;,
  options: {
  esModule: false, // 这里设置为false
  name: &#39;[name].[ext]&#39;,
  limit: 10240 
  } 
  }]
 }

オプション 2 に設定しました (推奨) )

require('~/images/2.png').default

まあまあです

ps: ただし、React Scaffolding 構成を使用する場合は、必要ありません.default を使用しますが、直接 require( url) を使用します。

2.2 ケース 2このケースでは、学習プロセス中に遭遇したことに基づいて、私のニーズを大まかに説明します。 React を使用してバックエンド管理システムを構築しました。その後、ローカル データを json 形式に変換し、React を通じてそれを読み取り、フロントエンド インターフェイスに表示する必要があります。ファイルにはテキストと画像が含まれています。テキストは読みやすいです。方法肝心な時に写真を入手するのが難しいところです。そこで、この困難をどのように克服したかについて話しましょう:

1) まず、以下に示すように、json データの一部をインターセプトしました:

{
  "success": true,
  "msg": "",
  "titleImg": "http:\/\/iwen.wiki\/sxtstu\/blueberrypai\/indexImg\/youjiIcon_38.png",
  "travelnote": [
    {
      "title": "\u8de8\u8d8a\u8d64\u9053\u7684\u871c\u6708\u884c-\u9189\u7f8e\u6bdb\u91cc\u6c42\u65af-1",
      "writer": "\u4f59\u982d\u5c0f\u59d0Rachel",
      "content": "\u82b1\u306e\u6642\u5149\u65c5\u884c \u3010\u6642\u5149\u65c5\u884c\u3011\u5e74\u8f7b\u5c31\u662f \u7528\u6765\u6298\u817e\u7684\uff0c\u6709\u529b\u6c14\u53bb\u60f3\uff0c  \u53bb\u505a\uff0c\u800c\u662f\u4e3a\u4e86\u7a33\u5b9a\u4e22\u6389\u9752\u6625\uff0c\u4e3a\u4e86\u5e73\u6de1\u4e22\u6389\u68a6",
      "img": "http:\/\/iwen.wiki\/sxtstu\/blueberrypai\/indexImg\/youji_38.png"
    },
    {
      "title": "\u8de8\u8d8a\u8d64\u9053\u7684\u871c\u6708\u884c-\u9189\u7f8e\u6bdb\u91cc\u6c42\u65af-2",
      "writer": "\u4f59\u982d\u5c0f\u59d0Rachel",
      "content": "\u82b1\u306e\u6642\u5149\u65c5\u884c \u3010\u6642\u5149\u65c5\u884c\u3011\u5e74\u8f7b\u5c31\u662f \u7528\u6765\u6298\u817e\u7684\uff0c\u6709\u529b\u6c14\u53bb\u60f3\uff0c  \u53bb\u505a\uff0c\u800c\u662f\u4e3a\u4e86\u7a33\u5b9a\u4e22\u6389\u9752\u6625\uff0c\u4e3a\u4e86\u5e73\u6de1\u4e22\u6389\u68a6",
      "img": "http:\/\/iwen.wiki\/sxtstu\/blueberrypai\/indexImg\/youji_38.pngg"
    }
  ]
}

2) フィールド img を取得する必要があります。

"img": "http:\/\/iwen.wiki\/sxtstu\/blueberrypai\/indexImg\/youji_38.pngg"

次に、img フィールドを取得します。取得されるのは画像ではなく単なるリンクであるため、画像を表示するには次のタグを使用する必要があります:

<img src={item.img} alt=&#39;图片未显示&#39;/>

うーん、見た目は完璧です。上記のリンクはサーバー上で読み取って表示できますが、ローカル画像の場合:

"img": "@/assets/imgs/cloud/Directory.svg"

は読み取れないため、このアイデアは最終的に合格となりました。

仕方なく他の方法をネットで探したところ、以下の記事を発見しました。

「ES6 Reactコンポーネントのローカルイメージ参照問題」

この記事は、ざっくりとした内容です。つまり、上記の 2 つの方法、方法 1 と方法 2 は、画像があまりなく、画像パスをフロントエンドに直接読み込むという問題を解決できます。それでは、データベースから画像のパスを読み取る必要があり、require は変数を書き込めず、import from は変数を書き込めない場合、どうすればよいでしょうか?で、この記事を読んでやってみたのですが、わからなくて諦めました。

最後に、require to read を使用した記事があり、最終的に私の問題を解決しました。参考 2 をご覧ください。ここでは私のアイデアについて話します。

require() の入力は文字列のみであると前に言いませんでしたか?したがって、img フィールドを 2 つの部分に分割できます: ファイル名 画像名

例:

ファイル名: '@/assets/images/'

画像名: item.img (コレクション全体を調べたのでこれを書きました)

json の img フィールドを変更します:

"img": "logo.jpg"

最後に、これは文字列の結合と同等です: @/assets /images /logo.jpg

require(&#39;@/assets/images/logo.jpg&#39;)

これでは目標は達成されませんか?

このように書くと読めない場合は、次のように書いてください:

<img  src={require(&#39;@/assets/images/&#39;+ item.img).default} / alt="反応使用は必要ですか?" >

推奨される学習: "

react ビデオ チュートリアル

"

以上が反応使用は必要ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。