contenteditable div append a html element and v-model it in Vuejs(Content edable div追加一个html元素,并在Vuejs中对其进行v建模)
本文介绍了Content edable div追加一个html元素,并在Vuejs中对其进行v建模的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
这是我的HTML代码。
<div id="app">
<button @click="renderHtml">clisdfsdfsdfck to appen html</button>
<div class="flex">
<div class="message" @input="fakeVmodel" v-html="html" contenteditable="true"></div>
<div class="message">{{ html }}</div>
</div>
</div>
这是js部件
let app = new Vue({
el: '#app',
data: {
html: 'some text',
},
methods: {
fakeVmodel: function(e){
this.html = e.target.innerText;
},
renderHtml: function(){
this.html += '<img src="aHR0cHM6Ly9jZG4taW1hZ2VzLTEubWVkaXVtLmNvbS9tYXgvODUzLzEqRkgxMmEyZlg2MWFIT24zOXBmZjl2QS5qcGVn" alt="IiB3aWR0aD0yMDBweCZndDs=";
}
}
});
问题是,当我单击按钮将html标记(Img)推送到我的变量(Html)时,它就起作用了。但在输入后,它将删除插入的标签部分。这是在Vue中成功添加到html代码的方法吗?
推荐答案
主要问题:
该html因this.html = e.target.innerText;
而消失。相反,请使用this.html = e.target.innerHTML;
。innerHTML
解析为完整的HTML内容。
次要问题:
键入后,光标将聚焦于div的开头。这是因为v-html
导致div更新。
若要解决此问题,请确保v-html
仅更新焦点输出时的div。
完整示例
数据-lang="js"数据-隐藏="假"数据-控制台="假"数据-巴贝尔="假">let app = new Vue({
el: '#app',
data: {
html: 'some text',
},
methods: {
updateHtml: function(e) {
this.html = e.target.innerHTML;
},
renderHtml: function(){
this.html += '<img src="aHR0cHM6Ly9jZG4taW1hZ2VzLTEubWVkaXVtLmNvbS9tYXgvODUzLzEqRkgxMmEyZlg2MWFIT24zOXBmZjl2QS5qcGVn" alt="IiB3aWR0aD0yMDBweCZndDs=";
}
}
});
<script src="aHR0cHM6Ly9jZG5qcy5jbG91ZGZsYXJlLmNvbS9hamF4L2xpYnMvdnVlLzIuNC40L3Z1ZS5qcw=="></script>
<div id="app">
<button @click="renderHtml">click to append html</button>
<div class="flex">
<div class="message" @focusout="updateHtml" v-html="html" contenteditable="true"></div>
<br>
<div class="message">{{ html }}</div>
</div>
</div>
这篇关于Content edable div追加一个html元素,并在Vuejs中对其进行v建模的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Content edable div追加一个html元素,并在Vuejs中对其


猜你喜欢
- 失败的 Canvas 360 jquery 插件 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- 400或500级别的HTTP响应 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- Fetch API 如何获取响应体? 2022-01-01