vue2.0(新手)第一个坑--do not mount Vue to <body>!!!

[javascript]  view plain  copy
  1. import Vue from 'vue';  
  2. import App from './App';  
  3.   
  4. /* eslint-disable no-new */  
  5. new Vue({  
  6.   el: '#app',  
  7.   template: '<App/>',  
  8.   components: { App }  
  9. });  

这是vue2.0的最新写法,我们看到的是vue项目的主入口main.js,template是将会替换el的挂载元素的模板

区别一定是:el对应的 一定是一个css选择器,如果还是html 或者body元素,如下图:

[javascript]  view plain  copy
  1. import Vue from 'vue';  
  2. import App from './App';  
  3.   
  4. /* eslint-disable no-new */  
  5. new Vue({  
  6.   el: 'body',  
  7.   components: { App }  
  8. });  

浏览器将会报错:

[plain]  view plain  copy
  1. [Vue warn]: Do not mount Vue to <html> or <body> - mount to normal elements instead.   
  2. warn @ vue.common.js?e881:509  
  3. vue.common.js?e881:5929 Download the Vue Devtools for a better development experience:  
  4. https://github.com/vuejs/vue-devtools  

,google translate:

不要将Vue挂载到<html>或<body> - mount到普通元素。


官方文档是这么解释的:


提供的元素只能作为挂载点。不同于 Vue 1.x,所有的挂载元素会被 Vue 生成的 DOM 替换。因此不推荐挂载root实例到 <html> 或者 <body> 上。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值