搜尋

首頁  >  問答  >  主體

javascript - Vue中如何引入一個html(包含css/js)作為一個模組

程式碼框架是vue webpack node

想在Vue寫的頁面中引入一個markdown插件editor.md https://github.com/pandao/edi... 作為一個模組

但是editor.md並不能透過npm安裝

editor.md外掛程式的html程式碼:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Editor</title>
</head>
<body>
<p id="editormd">
  <textarea style="display:none;">### Hello Editor.md !</textarea>
</p>

<link rel="stylesheet" href="css/editormd.min.css"/>
<script src="js/jquery.min.js"></script>
<script src="js/zepto.min.js"></script>
<script src="js/editormd.min.js"></script>
<script type="text/javascript">
  /* eslint-disable */
  $(function () {
    editormd("editormd", {
      width: "98%",
      height: 730,
      path: "lib/", // Autoload modules mode, codemirror, marked... dependents libs path
      codeFold: true,
      saveHTMLToTextarea: true,
      searchReplace: true,
      htmlDecode: "style,script,iframe|on*",
      emoji: true,
      taskList: true,
      tocm: true,                  // Using [TOCM]
      tex: true,                   // 开启科学公式TeX语言支持,默认关闭
      flowChart: true,             // 开启流程图支持,默认关闭
      sequenceDiagram: true,       // 开启时序/序列图支持,默认关闭,
      imageUpload: true,
      imageFormats: ["jpg", "jpeg", "gif", "png", "bmp", "webp"],
      imageUploadURL: "examples/php/upload.php",
      onload: function () {
        console.log('onload', this);
      }
    });
  });
</script>
</body>
</html>

效果如下:

想把這個當做一個模組放到vue實現的頁面中,不知該如何做到

怪我咯怪我咯2714 天前1077

全部回覆(2)我來回復

  • PHP中文网

    PHP中文网2017-06-12 09:31:24

    類似的第三方插件,都可以用這樣的方式組織成一個vue元件:

    <template>
    <p id="id">
        <textarea></textarea>
    </p>
    </template>
    <script>
    import scriptjs from 'scriptjs'
    export default {
        props: {
            id: String
        },
        mounted() {
            // 获取依赖的资源 - 如果需要异步加载的话
            Promise.all([
                scriptjs('jquery.min.js'),
                scriptjs('editormd.min.js')
            ])
            .then(() => {
                // do your logic.
                // 实例化,绑定事件等操作
            })
        },
        destoryed() {
            // 解绑全局事件
            // 销毁实例
        },
        methods: {
            // 返回一些有用的函数
        }
    }
    </script>

    實例化之後,監聽實例提供的方法;然後再$emit給使用者,再提供一些get方法來取得內部屬性,等等。

    具體的實作可以參考vue-ueditorvue-echarts類似的。

    使用方法:

    <editor-md id="editormd" @update="doUpdate"></editor-md>

    回覆
    0
  • 三叔

    三叔2017-06-12 09:31:24

    我的具體實現:
    先把editor.md需要的依賴(github上有)放到/static/editor.md/目錄下

    MainEditor.vue 元件代碼:

    <template>
      <p id="editor-md" class="main-editor">
        <textarea></textarea>
      </p>
    </template>
    
    <script>
      import $script from 'scriptjs';
    
      export default {
        name: 'EditDocMainEditor',
        props: {
          editorPath: {
            type: String,
            default: '/static/editor.md/',
          },
          editorConfig: {
            type: Object,
            default() {
              return {
                width: '88%',
                height: 530,
                path: '/static/editor.md/lib/', // Autoload modules mode, codemirror, marked... dependents libs path
                codeFold: true,
                saveHTMLToTextarea: true,
                searchReplace: true,
                htmlDecode: 'style,script,iframe|on*',
                emoji: true,
                taskList: true,
                tocm: true,                  // Using [TOCM]
                tex: true,                   // 开启科学公式TeX语言支持,默认关闭
                flowChart: true,             // 开启流程图支持,默认关闭
                sequenceDiagram: true,       // 开启时序/序列图支持,默认关闭,
                imageUpload: true,
                imageFormats: ['jpg', 'jpeg', 'gif', 'png', 'bmp', 'webp'],
                imageUploadURL: 'examples/php/upload.php',
                onload: () => {
                  // eslint-disable-next-line
                  console.log('onload', this);
                },
              };
            },
          },
        },
        data() {
          return {
            instance: null,
          };
        },
        created() {
        },
        mounted() {
          // async loading js dependencies
          // editormd depdend on jquery and zepto
          $script([
            `${this.editorPath}js/jquery.min.js`,
            `${this.editorPath}js/zepto.min.js`,
          ], () => {
            $script(`${this.editorPath}js/editormd.min.js`, () => {
              this.initEditor();
            });
          });
        },
        beforeDestroy() {
        },
        methods: {
          initEditor() {
            // eslint-disable-next-line
            this.$nextTick((editorMD = window.editormd) => {
              if (editorMD) {
                // Vue 异步执行 DOM 更新,template 里面的 script 标签异步创建
                // 所以,只能在 nextTick 里面初始化 editor.md
                this.instance = editorMD('editor-md', this.editorConfig);
              }
            });
          },
        },
      };
    </script>
    
    <style lang="stylus" scoped>
      .main-editor
        width 100%
        height 100%
        margin-top 100px;
    </style>
    

    /static/editor.md/css/editormd.min.css 需要在html中另外引入

    vue元件位址(模仿vue-ueditor): https://github.com/LaveyD/vue...

    回覆
    0
  • 取消回覆