今回は、画像のドラッグ アンド ペースト機能を実装するための vue-simplemde を紹介します (コード付き)。vue-simplemde で画像のドラッグ アンド ペースト機能を実装するための 注意事項 は次のとおりです。一見。
このプロジェクトは vue フレームワークを使用しており、マークダウン編集ボックスが必要です。npm で検索したところ、simplemde が非常に優れていることがわかりました。私は npm で再度検索し、vue
を見つけました。 >このパッケージを使用してから使用を開始してください。 vue-simplemde
这个 package ,那就开始使用它吧。
但是这个 vue-simplemde
不支持图片拖拽上传、粘贴上传,也不能说是因为这个 vue-simplemde ,因为 vue-simplemde 只是对 simplemde 的基础上封装成一个Vue插件。所以最后还是由于 simplemde 没有提供相关的功能,但是为了用户体验考虑,这个功能时必要的,除非不使用markdown编辑器。而去使用富文本编辑器,那样的话,项目很多的代码都要进行更改。所以就在网上查了文章,及在github上查了一些代码。下面将进行分析
拖拽
拖拽的API核心是 drop 这个事件,就是当我们从桌面拖动一个文件到浏览器里时,松开的时候,而触发的事件名。
我们都知道,你随便拖动一个图片到浏览器里,会直接打开这个图片,这是因为浏览器默认你拖动文件到浏览器里时,将打开这个文件,所以,我们需要阻止原生的操作。
我们现在先写一段代码,让其屏蔽掉默认事件
1 2 3 4 5 6 |
|
CodeMirror-scroll 这个Class就是 simplemde 编辑框的Class名称。
现在我们拖拽文件到这个编辑框,然后松掉,不会出现任何反应。如果在编辑框之外的地方,还是会继续触发默认事件。
下面就是获取 simplemde 方法,给他 drop 事件处理方法。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
|
诈一看,代码好像有点多,那是因为注释的原因,下面是没有注释的代码。你可以根据下面的代码,有自己的见解和理解:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
粘贴
粘贴的API是 paste 方法,这个不像上面一样,粘贴不需要禁止默认事件,因为我们可以看到,你复制一个图片,到浏览器里按下 ctrl+v 的时候,是不会发生任何变化的,所以没用必要禁止默认事件。
下面是代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
之所以这里写上 try...catch 方法,是因为如果你粘贴的时候,如果是一个文件, items 将是空的,而在下面的if循环里,使用 dataList[0].kind 。也就是 e.clipboardData.items[0].kind 。当 item 为空时,还去访问一个不存的 kind 属性时,就会报错了。所以这里需要使用 try...catch 方法进行判断。
dataList[0].getAsFile().type.indexOf('image') !== -1
vue-simplemde
は画像のドラッグ アンド ドロップ アップロードや貼り付けアップロードをサポートしていません。また、vue-simplemde は単なる Vue プラグインであるため、これが vue-simplemde のせいであるとは言えません。 simplemde に基づいています。結局のところ、simplemde が関連する機能を提供していないためですが、ユーザーエクスペリエンスのために、マークダウンエディターを使用しない場合を除き、この機能は必要です。代わりに、リッチ テキスト エディタを使用してください。その場合、プロジェクト内の多くのコードを変更する必要があります。そこで、オンラインの記事と github のコードを確認しました。以下が分析されます
ドラッグ アンド ドロップ
ドラッグ アンド ドロップ API の中核は、デスクトップからブラウザにファイルをドラッグして放したときにトリガーされるイベントの名前であるドロップ イベントです。それ。 画像をブラウザにドラッグすると、その画像が直接開かれることは誰もが知っています。これは、ファイルをブラウザにドラッグするとデフォルトでファイルが開かれるためです。そのため、ネイティブ操作を防ぐ必要があります。 デフォルトのイベントをブロックするコードを書いてみましょう1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
|
メソッドを与えます。
1 2 3 4 |
|
一見、コードが多すぎるように見えますが、これはコメントのせいです。 以下はコメントなしのコードです。以下のコードに基づいて独自の洞察と理解を得ることができます:
1 2 3 4 |
|
dataList[0].getAsFile().type.indexOf('image') !== -1
この文は、貼り付けられたものは画像であり、別のものではないことが確認されています。 。 🎜🎜ifでの画像アップロードの違いは[dataList[0].getAsFile()]ですが、形式を統一してuploadImagesFile関数での処理を容易にするために[]を付けて配列にしたためです。 dataList[0].getAsFile()はファイルインスタンスを取得します。 🎜🎜🎜🎜アップロード🎜🎜🎜🎜アップロードは少し面倒です: 🎜rrreee🎜 axiox を vue プラグインとしてカプセル化して使用するため、これにより this.$http 自体ではなくインスタンス化されます。 axios メンテナーが提案する解決策は、axios パッケージを再導入して使用することです。しかし、私はそれが必要だとは思いません。内部的には axios.all は Promise.all です。 axios.spread の実装コードは比較的小さいので、直接取得して axios に再割り当てするだけです🎜🎜したがって、上記のコードは 🎜rrreee🎜このコードを 🎜rrreee に翻訳します🎜 この問題については、公式の説明を読んでください: axios- vue コンポーネント内のすべては関数ではありません。 axios のコードもご覧ください: axios.js#L45-L48🎜🎜 この問題については、当面は深入りしません。先ほどの話題に戻りましょう。 🎜🎜状態が true の場合、データは /static/upload/2cfd6a50-3d30-11e8-b351-0d25ce9162a3.png のように、Web サイトを基準としたファイルの絶対パスであると上で述べました🎜この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。
推奨読書:
AJAX を介した jQuery エンコード変換の Base64 アップロード
以上がvue-simplemde は画像のドラッグアンドペースト機能を実装します (コードが添付されています)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。