首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VueJS + TinyMCE: TinyMCE只显示一次

VueJS + TinyMCE: TinyMCE只显示一次
EN

Stack Overflow用户
提问于 2015-12-03 06:23:09
回答 3查看 4K关注 0票数 2

请试一下代码片段。

我在Vue路由器中有很多组件,每个组件都有自己的TinyMCE编辑器来编辑内容。但是,只为第一个加载路由器显示TinyMCE。控制台中有一个错误:Permission denied to access property "document",只有当我将TinyMCE和Vue一起使用时,才会发生这种错误,我不知道这是否是问题的原因。

如果有人有解决办法,我就当学徒!

我有另一个版本的这个问题在jsfillde上:http://jsfiddle.net/tranduyhung/NF2jz/5105/。我不明白Permission denied to access property "document"在jsfiddle的错误。

代码语言:javascript
复制
var Foo = Vue.extend({
    template: '#foo',
  	ready: function() {
      // This doesn't help
      //tinyMCE.remove()

      tinyMCE.init({selector: "#tinymcefoo"})

      // This is not working
      //tinyMCE.execCommand('mceAddControl', false, '#tinymcefoo');
      //tinyMCE.execCommand('mceAddEditor', false, '#tinymcefoo');
    }
})

var Bar = Vue.extend({
    template: '#bar',
  	ready: function() {
      // This doesn't help
      //tinyMCE.remove()

      tinyMCE.init({selector: "#tinymcebar"})

      // This is not working
      //tinyMCE.execCommand('mceAddControl', false, '#tinymcefoo');
      //tinyMCE.execCommand('mceAddEditor', false, '#tinymcefoo');
    }
})

var App = Vue.extend({})
var router = new VueRouter()

router.map({
    '/foo': {
        component: Foo
    },
    '/bar': {
        component: Bar
    }
})

router.redirect({
  '*': '/foo'
})

router.start(App, '#app')
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/1.0.10/vue.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue-router/0.7.7/vue-router.min.js"></script>
<script src="//cdn.tinymce.com/4/tinymce.min.js"></script>


<div id="app">
  <p>Menu: <a v-link="{ path: '/foo' }">Working</a> | <a v-link="{ path: '/bar' }">Not working</a></p>
  <hr>
  <router-view></router-view>
  
<script type="text/x-template" id="foo">
  <p>Working</p>
  <textarea id="tinymcefoo"></textarea>
</script>

<script type="text/x-template" id="bar">
  <p>Not working</p>
  <textarea id="tinymcebar"></textarea>
</script>
</div>

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-12-03 06:38:05

尝试将文本区域设置为相同的类,并选择该类作为选择器:

代码语言:javascript
复制
<textarea id="tinymcefoo" class="my_editor"></textarea>
<textarea id="tinymcebar" class="my_editor"></textarea>

可随时使用

代码语言:javascript
复制
tinyMCE.init({selector: ".my_editor"});
票数 0
EN

Stack Overflow用户

发布于 2016-06-29 04:49:39

只需对tinyMCE进行一次集成,您就可以在应用程序开始时实现它。

代码语言:javascript
复制
tinceMCE.init({
  mode: 'none'
});

使用Vue的就绪事件和beforeDestroy事件在每次初始化时重新加载编辑器

代码语言:javascript
复制
var Foo = Vue.extend({
  // ...
  ready: function() {
    tinyMCE.execCommand('mceAddEditor', true, 'tinymcebar'); // id without '#'
  },
  beforeDestroy: function() {
    tinyMCE.execCommand('mceRemoveEditor', true, 'tinymcebar');
  }
}

链接到更新的小提琴

票数 1
EN

Stack Overflow用户

发布于 2017-02-26 09:44:29

是的,我找到了这样的解决方案:

代码语言:javascript
复制
// load tinymce placeholder plugin from from local static file
tinymce.PluginManager.load('placeholder', '/static/js/tinymce/plugins/tinymce-placeholder.plugin.js');

以下是我的TinyMceComponent:https://github.com/Doogiemuc/liquido-vue-frontend/blob/master/src/components/TinyMceComponent.vue的完整来源

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34059166

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档