Vue リッチ テキスト エディタ tinymce インストール チュートリアル (フロントエンドの知識が必要)

目次

1. Tinymceエディターの紹介

2. tinymceのインストールと設定

1. tinymceエディターをインストールします

2.node_modules/tinymce からスタイルを public ディレクトリにコピーします。コピーされた public 下のディレクトリ構造は次のとおりです。

3. Vueでの使用


1. Tinymceエディターの紹介

TinyMCE は、 JavaScript で書かれた軽量のブラウザベースの WYSIWYG エディタです。IE6 以降および Firefox1.5 以降に対する非常に優れたサポートがあります。機能面では最強とは言えませんが、ほとんどのWebサイトのニーズを確実に満たすことができ、機能構成も柔軟かつシンプルですもう 1 つの特徴は、読み込み速度が非常に速いことです。サーバーで使用されているスクリプト言語が PHP の場合は、さらに最適化することができます。最も重要なことは、TinyMCE は LGPL ライセンスに基づいてリリースされたフリー ソフトウェアであり、商用アプリケーションに使用できることです。

2. tinymceのインストールと設定

1. tinymceエディターをインストールします

npm i tinymce
npm i @tinymce/tinymce-vue

 インストールが完了しました

2.node_modules/tinymce からスタイルを public ディレクトリにコピーします。コピーされた public 下のディレクトリ構造は次のとおりです。

 (1) 次に、パブリック ディレクトリに新しいフォルダー ticymce を作成します。

(2). 上記で作成したフォルダーディレクトリにnode_modules/tinymce/tinymce.min.jsをコピーします。

(3). public/tinymce ディレクトリにフォルダskinsとlangsを作成します。

 (4).node_modules/tinymce/skins フォルダーを public/tinymce ディレクトリに直接コピーします。

 

 (5). 中国語の中国語言語パック zh-Hans.js のダウンロード アドレスを設定します。

言語パッケージ | 信頼できるリッチ テキスト エディタ | TinyMCE

ドロップダウンリストから「簡体字中国語」を選択し、「ダウンロード」をクリックします。

 ダウンロードが完了したら解凍します

 解凍が完了したら、解凍した zh-Hans.js を public/tinymce/langs フォルダーにコピーします。

現在のパブリック ディレクトリ内のファイル構造は次のとおりです。まったく同じです。

3. Vueでの使用

1. コンポーネント ディレクトリに新しい Editor.vue を作成し、次のコードをそこにコピーします

<template>
    <editor v-model="content" tag-name="div" :init="init" />
</template>
<script setup>
import tinymce from "tinymce/tinymce";
import Editor from "@tinymce/tinymce-vue";
import { ref, watch } from "vue"
import "tinymce/themes/silver/theme"; // 引用主题文件
import "tinymce/icons/default"; // 引用图标文件
import 'tinymce/models/dom'
// tinymce插件可按自己的需要进行导入
// 更多插件参考:https://www.tiny.cloud/docs/plugins/
import "tinymce/plugins/advlist"
import "tinymce/plugins/anchor"
import "tinymce/plugins/autolink"
import "tinymce/plugins/autoresize"
import "tinymce/plugins/autosave"
import "tinymce/plugins/charmap" // 特殊字符
import "tinymce/plugins/code" // 查看源码
import "tinymce/plugins/codesample" // 插入代码
import "tinymce/plugins/directionality"
import "tinymce/plugins/emoticons"
import "tinymce/plugins/fullscreen" //全屏
import "tinymce/plugins/help"
import "tinymce/plugins/image" // 插入上传图片插件
import "tinymce/plugins/importcss" //图片工具
import "tinymce/plugins/insertdatetime" //时间插入
import "tinymce/plugins/link"
import "tinymce/plugins/lists" // 列表插件
import "tinymce/plugins/media" // 插入视频插件
import "tinymce/plugins/nonbreaking"
import "tinymce/plugins/pagebreak" //分页
import "tinymce/plugins/preview" // 预览
import "tinymce/plugins/quickbars"
import "tinymce/plugins/save" // 保存
import "tinymce/plugins/searchreplace" //查询替换
import "tinymce/plugins/table" // 插入表格插件
import "tinymce/plugins/template" //插入模板
import "tinymce/plugins/visualblocks"
import "tinymce/plugins/visualchars"
import "tinymce/plugins/wordcount" // 字数统计插件
// v-model
const props = defineProps({
    modelValue: String,
})
const emit = defineEmits(["update:modelValue"])
// 配置
const init = {
    language_url: '/tinymce/langs/zh-Hans.js', // 中文语言包路径
    language: "zh-Hans",
    skin_url: '/tinymce/skins/ui/oxide', // 编辑器皮肤样式
    content_css: "/tinymce/skins/content/default/content.min.css",
    menubar: false, // 隐藏菜单栏
    autoresize_bottom_margin: 50,
    max_height: 500,
    min_height: 450,
    // height: 320,
    toolbar_mode: "none",
    plugins:
        'wordcount visualchars visualblocks template searchreplace save quickbars preview pagebreak nonbreaking media insertdatetime importcss image help fullscreen directionality codesample code charmap link code table lists advlist anchor autolink autoresize autosave',
    toolbar:
        "formats undo redo fontsizeselect fontselect ltr rtl searchreplace media | outdent indent aligncenter alignleft alignright alignjustify lineheight underline quicklink h2 h3 blockquote numlist bullist table removeformat forecolor backcolor bold italic strikethrough hr link preview fullscreen help ",
    content_style: "p {margin: 5px 0; font-size: 14px}",
    fontsize_formats: "12px 14px 16px 18px 24px 36px 48px 56px 72px",
    font_formats: "微软雅黑=Microsoft YaHei,Helvetica Neue,PingFang SC,sans-serif;苹果苹方= PingFang SC, Microsoft YaHei, sans- serif; 宋体 = simsun, serif; 仿宋体 = FangSong, serif; 黑体 = SimHei, sans - serif; Arial = arial, helvetica, sans - serif;Arial Black = arial black, avant garde;Book Antiqua = book antiqua, palatino; ",
    branding: false,
    elementpath: false,
    resize: false, // 禁止改变大小
    statusbar: false, // 隐藏底部状态栏
}
tinymce.init; // 初始化
const content = ref(props.modelValue)
watch(props, (newVal) => content.value = newVal.modelValue)
watch(content, (newVal) => emit("update:modelValue", newVal))
</script>
<style>
.tox-tinymce-aux {
    z-index: 9999 !important;
}
</style>

app.vue でコードを作成し、コンポーネント Editor.vue をインポートします

<template>
    <Editor v-model="content" />
</template>



<script setup>
import { ref } from "vue"
import Editor from "/src/components/Editor.vue"
const form = ref({
    content: ''
})
</script>

 インポートが成功すると、リッチ テキスト エディターが表示され、通常どおり編集できます。

 ディレクトリ構造は次のとおりです

おすすめ

転載: blog.csdn.net/qq_63299825/article/details/131093692