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

来源:互联网 发布:网络十大神豪 编辑:程序博客网 时间:2024/06/14 03:32

[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> 上。

原创粉丝点击