经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML » 查看文章
v-html渲染组件问题
来源:jb51  时间:2021/5/31 10:59:01  对本文有异议

由于前面对html进行过解析,今天想用vue拖拽,实现一手类似快站那种自动生成代码,结果就遇到了拖拽组件过去怎么无法解析的问题,因为vue的v-html为了防止xss攻击只能解析html

思路

 先实现简单页面 分三块左中右,左边是需要拖动的组件,中间是用于组件排列显示,右边是解析出的代码

左边组件列表代码

  1. <div ref="test" >
  2. <one-component :title="title[0]" element="<el-radio v-model='radio' label='1'>备选项</el-radio>">
  3. <el-radio slot="component" v-model="radio" label="1">备选项</el-radio>
  4. </one-component>
  5. </div>
  6. </template>
  7.  
  8. <script>
  9. import OneComponent from '../components/oneComponent'
  10. export default {
  11. name: '',
  12. data() {
  13. return {
  14. radio: '2',
  15. title: ['Radio 单选框']
  16. }
  17. },
  18. components:{
  19. OneComponent
  20. },
  21.  
  22. }
  23. </script>
  24.  
  25. <style lang="stylus" scoped>
  26. </style>

中间组件显示代码

  1. <div class="all">
  2. <el-form label-width="80px" label-position="left" :model="ruleForm" :rules="rules">
  3. <el-form-item label="模拟宽" prop="inputW">
  4. <el-input v-model="ruleForm.inputW" placeholder="请输入宽"></el-input>
  5. </el-form-item>
  6. <el-form-item label="模拟高" prop="inputH">
  7. <el-input v-model="ruleForm.inputH" placeholder="请输入高"></el-input>
  8. </el-form-item>
  9. </el-form>
  10. <Variablebox
  11. class="box"
  12. :width="ruleForm.inputW"
  13. :height="ruleForm.inputH"
  14. ></Variablebox>
  15. </div>
  16. </template>
  17. <script>
  18. import Variablebox from "../components/Variablebox";
  19. export default {
  20. name: "",
  21. data() {
  22. var checkSize = (rule, value, callback) => {
  23. console.log(value);
  24. if (value < 500 || value > 1000) {
  25. callback(new Error("建议500 ~ 1000内的数字"));
  26. } else if (!Number.isInteger(Number(value))) {
  27. callback(new Error("请输入数字值"));
  28. } else {
  29. callback();
  30. }
  31. };
  32. return {
  33.  
  34.  
  35. ruleForm: {
  36. inputW: 500,
  37. inputH: 500
  38. },
  39.  
  40. rules: {
  41. inputW: [{ validator: checkSize, trigger: "blur" }],
  42. inputH: [{ validator: checkSize, trigger: "blur" }]
  43. }
  44. };
  45. },
  46. methods: {
  47. },
  48. components: {
  49. Variablebox
  50. }
  51. };
  52. </script>
  53. <style lang="stylus" scoped>
  54. .all
  55. padding: 0 20px
  56. display: flex
  57. flex-direction: column
  58. </style>

接下来实现组件的拖拽使用drag和drop 将组件显示在Variablebox页面上,使用v-html无效后,百度了一下,发现基本上叫使用vue.Vue.compile( template ) 和render但是没给例子

compile是将一个模板字符串编译成 render 函数,就是最后
都是render调用createElement,转化成html,但是我们我们是直接渲染
</el-radio slot="component" v-model="radio" label="1"/>
所以个人
感觉行不通,最后只能尝试新建组件然后挂载上去

  1. new Vue({
  2. // el: ‘#app'
  3. template: this.ele,
  4. data:{
  5. radio: '2'
  6. },
  7. }).$mount("#apps");
  8.  

这样算是暂时决解掉这个问题吧

vue中运用v-html渲染标签

获取后台数据带 标签 内容,需要渲染到页面展示。最终效果如下:图文排版

1.首先拿到数据,单独处理

2.接着在html中输出即可

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号