浅谈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 相关文章推荐
jQuery select控制插件
Aug 17 Javascript
超越Jquery_01_isPlainObject分析与重构
Oct 20 Javascript
Javascript基础教程之数据类型 (数值 Number)
Jan 18 Javascript
jQuery中的siblings用法实例分析
Dec 24 Javascript
纯javascript版日历控件
Nov 24 Javascript
jQuery仿写百度百科的目录树
Jan 03 Javascript
vue路由嵌套的SPA实现步骤
Nov 06 Javascript
详解关于element el-button使用$attrs的一个注意要点
Nov 09 Javascript
基于Fixed定位的框选功能的实现代码
May 13 Javascript
vue中更改数组中属性,在页面中不生效的解决方法
Oct 30 Javascript
详解vue或uni-app的跨域问题解决方案
Feb 21 Javascript
使用js原生实现年份轮播选择效果实例
Jan 12 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
php学习之数据类型之间的转换介绍
2011/06/09 PHP
PHP使用反射机制实现查找类和方法的所在位置
2016/04/22 PHP
Thinkphp单字母函数使用指南
2016/05/08 PHP
Array对象方法参考
2006/10/03 Javascript
脚本安需导入(装载)的三种模式的对比
2007/06/24 Javascript
javascript基本算法汇总
2016/03/09 Javascript
Three.js快速入门教程
2016/09/09 Javascript
Angular 输入框实现自定义验证功能
2017/02/19 Javascript
老生常谈js-react组件生命周期
2017/05/02 Javascript
js数组方法reduce经典用法代码分享
2018/01/07 Javascript
小程序文字跑马灯效果
2018/12/28 Javascript
解决vue elementUI中table里数字、字母、中文混合排序问题
2020/01/07 Javascript
JavaScript中break、continue和return的用法区别实例分析
2020/03/02 Javascript
详解微信小程序入门从这里出发(登录注册、开发工具、文件及结构介绍)
2020/07/21 Javascript
[14:24]Optic Gaming vs PSG LGD BO3
2018/06/07 DOTA
尝试使用Python多线程抓取代理服务器IP地址的示例
2015/11/09 Python
python中私有函数调用方法解密
2016/04/29 Python
python使用标准库根据进程名如何获取进程的pid详解
2017/10/31 Python
python查看模块,对象的函数方法
2018/10/16 Python
浅谈python函数调用返回两个或多个变量的方法
2019/01/23 Python
python常见字符串处理函数与用法汇总
2019/10/30 Python
Django 返回json数据的实现示例
2020/03/05 Python
Python Django2 model 查询介绍(条件、范围、模糊查询)
2020/03/16 Python
Python3爬虫中关于中文分词的详解
2020/07/29 Python
解决Python安装cryptography报错问题
2020/09/03 Python
通用的Django注册功能模块实现方法
2021/02/05 Python
佳能德国网上商店:Canon德国
2017/03/18 全球购物
Needle & Thread官网:英国仙女品牌
2018/01/13 全球购物
Priority Pass机场贵宾室会籍计划:全球超过1200间机场贵宾室
2018/08/26 全球购物
产假请假条
2014/04/10 职场文书
大学应届毕业生求职信
2014/05/24 职场文书
幼儿园大班见习报告
2014/10/31 职场文书
SQL Server连接查询的实用教程
2021/04/07 SQL Server
利用Python网络爬虫爬取各大音乐评论的代码
2021/04/13 Python
通过feDisplacementMap和feImage实现水波特效
2022/04/24 HTML / CSS