浅谈vue在html中出现{{}}的原因及解决方式


Posted in Javascript onNovember 16, 2020

原因:

浏览器渲染机制,解析html结构 -> 加载外部脚本和样式表文件 -> 解析并执行脚本代码 -> 构造html dom模型 -> 加载图片等外部文件 -> 页面加载完毕。

初始化vue的js写在页面底部,也就是最后才执行js脚本。

所以页面从头到尾开始渲染时,渲染到标签时,由于vue还未初始化,所以就会显示类似这样的代码

<h2>{{courseName}}</h2>

当网速很慢的时候就看得比较清楚,可能会让用户误以为bug之类的,快一点的话就是一闪而过,体验不是很好

解决办法:

1、网上说的很多都是用v-cloak,

<div id="app" v-cloak>
  {{context}}
</div>
[v-cloak]{
  display: none;
}

但是我用了下无效,可能哪里使用的不对?然后就干脆按自己的思路实现了

2、我现在实现解决的方式,给最外层div加个class='hide'(.hide{display: none},注意这个样式要写在head里),然后在vue初始化完成后,移除这个类hide,大概代码如下

<!DOCTYPE html>
<html lang="en">
 
<head>
 <meta charset="utf-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge">
 <meta name="viewport"
  content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, viewport-fit=cover">
 <title>标题</title>
 <style>
  .hide{
   display: none;
  }
 </style>
</head>
<body>
 <div id="app" class="hide">
  <h2>{{courseName}}</h2>
 </div>
 <script>
  //初始化vue
  initVue()
 
  function initVue() {
   new Vue({
    el: '#app',
    data: function () {
     return {
      datas:{
       courseName:''
      }
     }
    },
    mounted() {
     //移除隐藏样式
     document.querySelector('#app').classList.remove('hide')
    }
   })
  }
 </script>
</body>

补充知识:原生js和vue之间的数据通讯--EventEmitter

有个小项目在原来原生的框架编写,但是不想写原生,就引入了vue

然后有个需求要和原生的js进行交互通讯,于是就可以用node.js EventEmitter

具体做法:

先引入文件<script src="../../js/eventEmitter.js"></script>,

初始化,

然后在vue里面发送emit,

在外面监听on

var event = new EventEmitter();
$(document).ready(function () {
  //监听some_event事件
  event.on('some_event', function (data) {
    
  });
})
 
let vm = new Vue({
  el: "#app",
  methods: {
    getList() {
      // 触发事件
      event.emit('some_event','params');
    },
  }
});

附上eventEmitter.js

class EventEmitter {
 constructor() {
  this.event = {};
  this.maxListerners = 10;
 }
 // 监听
 on(type, listener) {
  if (this.event[type]) {
   if (this.event[type].length >= this.maxListerners) {
    console.error('同一个监听器最多被十个对象监听,否则可能造成内存泄漏.\n');
    return;
   }
      if (!this.event[type].includes(listener)) {
        this.event[type].push(listener);
      }
  } else {
   this.event[type] = [listener];
  }
 }
 //发送监听
 emit(type, ...rest) {
  if (this.event[type]) {
   this.event[type].map(fn => fn.apply(this, rest));
  }
 }
 //移除监听器
 removeListener(type,func) {
  if (this.event[type]) {
      this.event[type] = this.event[type].filter(item => item !== func);
      if (this.event[type].length === 0) {
        delete this.event[type];
      }
  }
 }
 //移除所有的监听器
 removeAllListener() {
  this.event = {};
 }
}

以上这篇浅谈vue在html中出现{{}}的原因及解决方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript学习笔记(十四) window对象使用介绍
Jun 20 Javascript
Extjs中通过Tree加载右侧TabPanel具体实现
May 05 Javascript
jQuery中bind与live的用法及区别小结
Jan 27 Javascript
jquery自定义插件——window的实现【示例代码】
May 06 Javascript
window.open不被拦截的简单实现代码(推荐)
Aug 04 Javascript
Javascript之面向对象--封装
Dec 02 Javascript
javascript监听页面刷新和页面关闭事件方法详解
Jan 09 Javascript
Angular.js与node.js项目里用cookie校验账户登录详解
Feb 22 Javascript
Windows下Node爬虫神器Puppeteer安装记
Jan 09 Javascript
vue使用recorder.js实现录音功能
Nov 22 Javascript
javascript用defineProperty实现简单的双向绑定方法
Apr 03 Javascript
微信小程序学习之自定义滚动弹窗
Dec 20 Javascript
vue组件中传值EventBus的使用及注意事项说明
Nov 16 #Javascript
小程序自定义弹框效果
Nov 16 #Javascript
vuex中遇到的坑,vuex数据改变,组件中页面不渲染操作
Nov 16 #Javascript
基于Vue+Webpack拆分路由文件实现管理
Nov 16 #Javascript
小程序实现上下切换位置
Nov 16 #Javascript
小程序实现点击tab切换左右滑动
Nov 16 #Javascript
微信小程序实现滚动Tab选项卡
Nov 16 #Javascript
You might like
超外差式晶体管收音机的组装与统调
2021/03/01 无线电
php set_time_limit(0) 设置程序执行时间的函数
2010/05/26 PHP
一个漂亮的php验证码类(分享)
2013/08/06 PHP
php使用正则表达式进行字符串搜索的方法
2015/03/23 PHP
PHP中的traits简单使用实例
2015/05/13 PHP
找到了一篇jQuery与Prototype并存的冲突的解决方法
2007/08/29 Javascript
图片上传即时显示缩略图的js代码
2009/05/27 Javascript
js控制CSS样式属性语法对照表
2012/12/11 Javascript
详解JavaScript函数绑定
2013/08/18 Javascript
基于JavaScript制作霓虹灯文字 代码 特效
2015/09/01 Javascript
JS实现的N多简单无缝滚动代码(包含图文效果)
2015/11/06 Javascript
js实现图片无缝滚动
2015/12/23 Javascript
Bootstrap框架下下拉框select搜索功能
2020/03/26 Javascript
Bootstrap登陆注册页面开发教程
2016/07/12 Javascript
jquery插件treegrid树状表格的使用方法详解(.Net平台)
2017/01/03 Javascript
Bootstrap表单使用方法详解
2017/02/17 Javascript
详解Vue 多级组件透传新方法provide/inject
2018/05/09 Javascript
JavaScript数组去重的几种方法
2019/04/07 Javascript
使用uni-app开发微信小程序的实现
2019/12/13 Javascript
Vue 解决父组件跳转子路由后当前导航active样式消失问题
2020/07/21 Javascript
Postman内建变量常用方法实例解析
2020/07/28 Javascript
python判断windows隐藏文件的方法
2014/03/21 Python
用Python写飞机大战游戏之pygame入门(4):获取鼠标的位置及运动
2015/11/05 Python
python初学之用户登录的实现过程(实例讲解)
2017/12/23 Python
python获取代码运行时间的实例代码
2018/06/11 Python
python多个模块py文件的数据共享实例
2019/01/11 Python
html5唤醒APP小记
2019/03/27 HTML / CSS
ASP.NET中的身份验证有那些
2012/07/13 面试题
法律专业个人实习自我鉴定
2013/09/23 职场文书
初中生个人学习的自我评价
2013/12/04 职场文书
施工人员岗位职责
2013/12/12 职场文书
母亲追悼会答谢词
2014/01/27 职场文书
职位证明模板
2015/06/23 职场文书
素质教育学习心得体会
2016/01/19 职场文书
七年级写作指导之游记作文
2019/10/07 职场文书
Oracle笔记
2021/04/05 Oracle