01、vue 2 初体验

一、 Vue程序初体验

先不去了解Vue框架的发展历史,Vue框架的特点,Vue的作者,这些对于我们开发来说,没有什么特别的作用,我们先学会基本使用,然后再去详细了解它的特点,就会发现,原来如此。

但我们需要指导Vue是一个基于JavaScript(JS)实现的框架,想要使用它,就得先拿到Vue的js文件

Vue官网

Vue2:https://v2.cn.vuejs.org/

Vue3:https://cn.vuejs.org/

目前最新的是Vue3,企业也大量使用到,但Vue3在Vue2的基础上,先学习Vue2,Vue3学习会事半功倍,且企业也有大量的Vue2项目需要进行维护,所以Vue2必须要掌握

1.1 下载并安装vue.js

第一步:打开Vue2官网,点击下图所示的"起步":

第二步:继续点击下图所示的"安装"

第三步:在"安装"页面向下滚动,直到看到下图所示位置:

第四步:点击开发版本,并下载

第五步:安装Vue

使用script标签引入vue.js文件。就像这样:

javascript 复制代码
<script src="xx/vue.js"></script>

1.2 、第一个Vue程序

1.2.1、先创建Vue第一个程序

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>第一个Vue程序</title>
    <!-- 第一步:引入Vue.js -->
    <script src="../js/vue.js"></script>
</head>
<body>
    <!-- 第二步:指定挂载位置 -->
    <div id="app"></div>
    <!-- 第三步:使用Vue -->
    <script>
        // 3.1创建Vue实例
        const vm=new Vue({
            template:'<h1>hello world!</h1>'
        })
        // 3.2 将Vue实例挂载到指定位置
        vm.$mount('#app')
       // vm.$mount(document.getElementById("app"));
    </script>
</body>
</html>

1.2.2、解释说明:

1、当使用script引入Vue.js之后,Vue会被注册为一个全局变量,就像引入jQuery之后,jQuery也会被注册为一个全局变量,通过控制台可以看到这个Vue全局变量

2、必须new一个Vue实例,如果不new的话,是无法直接使用Vue的

第一步:创建一个空对象,作为将要返回的对象。 let vm = {}

第二步:将这个空对象的原型指向构造函数的prototype属性,也就是将对象的__proto__属性指向构造函数的prototype。

【让对象能沿着原型链去使用构造函数中prototype上的方法】 vm.proto = Vue.prototype

第三步:将这个空对象赋值给构造函数内部的this关键字,执行构造函数。【让构造器中设置的属性和方法设置在这个对象上】

Vue.apply(vm, 参数)

第四步:返回这个对象。 return vm

3、Vue的构造方法参数是一个options配置对象,配置对象中有大量Vue预定义的配置,每一个配置项都是key:value结构,一个key:value就是一个Vue的配置项

4、template配置项:value是一个模版字符串,在这里编写符合Vue语法规则的代码(Vue有一套自己规定的语法规则)

写在这里的字符串会被Vue编译器编译,将其转换为浏览器能够识别的HTML代码,template称之为模版

5、Vue实例的$mount方法,这个方法完成挂载工作,将Vue实例挂载到指定位置,也就是将Vue编译后的HTML代码渲染到页面指定的位置,注意:指定位置的元素会被替换

6、'#app'的语法类似于css中的id选择器语法,表示将Vue实例挂载到id='app'的元素位置,也可以用其他选择器,如果匹配到多个位置,Vue只会选择第一个位置进行挂载(从上到下第一个),或者直接用原声js去获取:vm.$mount(document.getElementById("app"));

1.3 、Vue的data配置项

如果仅仅像我们以上书写的程序,我们完全没有必要使用Vue,直接在body里直接书写就可以了:

在Vue中还有一个data的配置项,它可以帮助我们动态的渲染页面:

1.3.1、代码如下

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>模板语句的数据来源</title>
    <!-- 引入Vue -->
    <script src="../js/vue.js"></script>
  </head>
  <body>
    <!-- 指定挂载位置 -->
    <div id="app"></div>
    <!-- vue程序 -->
    <script>
      new Vue({
        // template: `<h1>我叫张三,我今年18岁了</h1>`,
        template: `<h1>我叫{{name}},我今年{{age}}岁了</h1>`,
        //1.1 data函数写法
        // data: function () {
        //   return {
        //     name: "章三",
        //     age: 28,
        //   };
        // },
        //1.2 data函数简写
        // data() {
        //   return {
        //     name: "章三",
        //     age: 28,
        //   };
        // },
        // 2、data对象写法
        data: {
          name: "李四",
          age: 18,
          hobby: ["跑步", "游泳", "学习"],
          salary: {
            base: "5k",
            bonus: {
              month: "5k",
              year: "10k",
            },
          },
        },
      }).$mount("#app");
    </script>
  </body>
</html>

1.3.2、代码解释

1、data是Vue实例的数据对象,是给整个Vue实例提供数据来源的

2、data配置项的value值,有两种写法 Object|Function(对象或者函数),现阶段,这两种写法都可以,后期学到组件化的时候,data只能是函数的写法

3、如果data是对象的写法,对象必须是存粹的对象(含有0个或多个key:value)

4、data数据插入到模版语句中,可以用{{}},这是Vue框架自己搞的一个语法,叫插值语法(或叫胡子语法),可以从data根据key获取value,并且将value插入到对应的位置,注意{{}}语法是固定语法,不可以添加其他内容,例如空格{ { }}

5、data可以写多级,然后去一级一级获取

6、Vue编译器对template进行编译,遇到{{}}语法时,就去data里取数据,然后将获取到的数据插入到对应的位置,生成对应的html代码,最终将html渲染到挂载位置,呈现

7、当data发生改变时,template模版就会被重新编译,重新渲染

1.4、 Vue的template配置项

1.4.1、具体代码

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>template配置项详解</title>
    <!-- 引入Vue -->
    <script src="../js/vue.js"></script>
  </head>
  <body>
    <!-- 指定挂载位置 -->
    <!-- 注意:以下代码是Vue框架能看懂的代码了。
        下面的代码就是一个模板语句。这个代码是需要Vue框架编译,然后渲染的。 -->
    <div id="app">
      <!-- <div>
        <h1>{{msg}}</h1>
        <h1>{{name}}</h1>
      </div> -->
    </div>

    <!-- vue程序 -->
    <script>
      new Vue({
        // 错误的
        //template : '<h1>{{msg}}</h1><h1>张三</h1>',
        template: `
            <div>
                <h1>{{msg}}</h1>
                <h1>{{name}}</h1>
            </div>
            `,
        data: {
          msg: "Hello World!!!!!!!",
          name: "张三",
        },
      }).$mount("#app");
    </script>
  </body>
</html>

1.4.2、代码解释

1、template只能有一个根元素,只要data数据发生变化,template就会重新编译

2、template编译后进行渲染时会将挂载位置的元素替换。

3、template后面的代码如果需要换行的话,建议将代码写到``符号当中,不建议使用 + 进行字符串的拼接。

4、template配置项可以省略,将其直接编写到HTMl代码中,此时指定挂载的位置就不会被替换

5、只要data中的数据发生了变化,模版语句就一定会重新编译

1.5、el配置项

1.5.1、具体代码

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>el配置项</title>
    <!-- 引入Vue -->
    <script src="../js/vue.js"></script>
  </head>
  <body>
    <!-- 指定挂载位置 -->
    <div id="app">
      <div>
        <h1>{{msg}}</h1>
        <h1>{{name}}</h1>
      </div>
    </div>
    <!-- vue程序 -->
    <script>
      new Vue({
        data: {
          msg: "Hello World!!!!!!!",
          name: "张三",
        },
        // el配置项:确定挂载对象
        el: "#app",
        //el : document.getElementById('app')
      });
      //}).$mount('#app')
    </script>
  </body>
</html>

1.5.2 、代码解释

1、可以不使用$mount('#app')的方式进行挂载了。在Vue中有一个配置项:el ,

el配置项和$mount()可以达到同样的效果。

2、el配置项的作用?

el是element单词的缩写,翻译为"元素",el配置项主要是用来指定Vue实例关联的容器。也就是说Vue所管理的容器是哪个。

el : '#app',表示让Vue实例去接管id='app'的容器。

1.6、解决控制台的提示信息和错误信息

1.6.1、去除生产提示

Vue.config 是一个对象,包含 Vue 的全局配置,其中有个属性productionTip,设置为

false 以阻止 vue 在启动时生成生产提示。

javascript 复制代码
// 有时不生效,可能因为版本问题,彻底解决办法,去源码里修改
Vue.config.productionTip = false

1.6.2、安装Vue Devtools

第一步:极简插件:极简插件官网_Chrome插件下载_Chrome浏览器应用商店下载

第二步:将下载解压好的crx文件,安装到浏览器中

注意,数据如果是纯中文,可能是显示不出来对应组件的数据区域的

1.7、Vue实例和容器一一对应

一个Vue实例只能接管一个容器。一旦接管到容器之后, 即使后面有相同的容器,Vue也是不管的。因为Vue实例已经"娶到媳妇"了。

javascript 复制代码
  <body>
    <!-- 准备容器 -->
    <div class="app">
      <h1>{{msg}}</h1>
    </div>

    <div class="app">
      <h1>{{msg}}</h1>
    </div>

    <!-- 准备容器 -->
    <div id="app2">
      <h1>{{name}}</h1>
    </div>

    <!-- vue程序 -->
    <script>
      /* 
     验证:一个Vue实例可以接管多个容器吗?
不能。一个Vue实例只能接管一个容器。一旦接管到容器之后,
    即使后面有相同的容器,Vue也是不管的。因为Vue实例已经"娶到媳妇"了。
        */
      new Vue({
        el: ".app",
        data: {
          msg: "Hello Vue!",
        },
      });

      new Vue({
        el: "#app2",
        data: {
          name: "zhangsan",
        },
      });
     new Vue({
            el: "#app2",
            data: {
              name: "lisi",
            },
          });
    </script>
  </body>
相关推荐
).(7 分钟前
el-table横向滚动条,滚动后消失
前端·css·css3
兩尛11 分钟前
Web后端开发总结(day14)
java·开发语言
zhuangvi12 分钟前
Element Plus 之 el-table相同行合并(通用函数),相同列合并(自行判断需合并的字段以及相应的列下标)
elementui·前端框架
微臣酒驾来迟13 分钟前
el-descriptions-item使用span占行不生效
前端·javascript·vue.js
电子云与长程纠缠15 分钟前
UE5中制作地形材质
开发语言·缓存·ue5·编辑器·材质
froginwe1118 分钟前
《DOM NodeList》
开发语言
lly20240626 分钟前
XML 解析器:深入解析与高效应用
开发语言
明月看潮生37 分钟前
青少年编程与数学 02-006 前端开发框架VUE 22课题、状态管理
前端·javascript·vue.js·青少年编程·编程与数学
禾小毅37 分钟前
vue 实现打包并同时上传至服务器端
前端·vue.js
Front_Yue38 分钟前
Vue虚拟DOM:如何提高前端开发效率
前端·javascript·vue.js