✨✨ 欢迎大家来到景天科技苑✨✨
🎈🎈 养成好习惯,先赞后看哦~🎈🎈
Vue
Vue是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,可以高效地开发用户界面。无论是简单还是复杂的界面,Vue 都可以胜任。
Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
vue.js库的下载
vue.js是目前前端web开发最流行的工具库
官方文档
有开发版本,有生产版本
它就是个js,跟jquery使用方式类似
可以通过cdn给的网址,把代码下载到本地使用
vue.js目前有1.x、2.x和3.x 版本,我们学习2.x版本的。2.x到3.x是平滑过渡的,也就是说你之前用2.x写的代码,用3.x的版本的vue.js也是没问题的。
MVVM模型
M:数据操作
V:视图 把html标签称为视图
VM:数据驱动视图的核心功能,自动把数据驱动到视图中去生成
vue.js库的基本使用
在github下载:https://github.com/vuejs/vue/releases
vue的引入类似于jQuery,开发中可以使用开发版本vue.js,产品上线要换成vue.min.js。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="js/vue.min.js"></script> </head> <body> <div id="app"> <!-- {{ message }} 表示把vue对象里面data属性中的对应数据输出到页面中 --> <!-- 在双标签中显示数据要通过{{ }}来完成 --> <p>{{ message }}</p> </div> </body> <script> // vue.js的代码开始于一个Vue对象。所以每次操作数据都要声明Vue对象开始。 let vm = new Vue({ el:'#app', // 设置当前vue对象要控制的标签范围。 // data属性写法方式1 data:{ // data是将要展示到HTML标签元素中的数据。 message: 'hello world!', } // 方式2 // data:function () { // return { // 'msg':'掀起你的盖头来1!' // } // } // 方式3 data(){ // 单体模式 这种写法用的居多,并且后面学习中有个地方一定要这样写,所以我们就记下来这种写法就可以了 return { 'msg':'掀起你的盖头来2!', } } }); </script> </html>
由于不需要后端框架,我们可以用pycharm新建个python的项目
将vue的代码拷贝过来,新建个js文件
在html中引入vue代码
使用方法:
浏览器查看,可以看到h标签的内容,就是通过msg变量传递过来的
MVVM模型过程:
data 属性有好几种写法,还一种写法是以函数形式,return返回数据。这种方法最常用。因为模块化开发中,定义了vue的组件,必须这样写
单体模式
// 首先先实例化一个vue对象,里面传一些参数 let vm = new Vue({ el:'#app', // 此时表示通过vue语法来控制id为app的标签,在这个标签范围内可以使用vue语法 //通过data属性来接收后端的数据来展示到前端 // data:{ // msg:'aa', //比如从后端获取到aa这个值 // // } //可以单体模式,省略function data:function (){ return { msg:'hello word', } } })
el:圈地,划地盘,设置vue可以操作的html内容范围,值就是css的id选择器,其他选择器也可以,但是多用id选择器。
data: 保存vue.js中要显示到html页面的数据。
渲染数据的时候,使用{{}}跟Django模板渲染有点像,方便做前后端分离项目
vue中的变量可以直接进行一些简单直接的js操作
<div id="app"> <!-- vue的模板语法,和django的模板语法类似 --> <h2>{{ msg }}</h2> <!-- 放一个变量,会到data属性中去找对应的值 --> <!-- 有人说,我们直接这样写数据不就行吗,但是你注意,我们将来的数据都是从后端动态取出来的,不能写死这些数据啊,你说对不对 --> <h2>{{ 'hello beautiful girl!' }}</h2> <!-- 直接放一个字符串 --> <h2>{{ num+1 }}</h2> <!-- 四则运算 --> <h2>{{ 2+1 }}</h2> <!-- 四则运算 --> <h2>{{ {'name':'chao'} }}</h2> <!-- 直接放一个自定义对象 --> <h2>{{ person.name }}</h2> <!-- 下面data属性里面的person属性中的name属性的值 -->
<h2>{{ 1>2?'真的':'假的' }}</h2> <!-- js的三元运算 -->
<h2>{{ msg2.split('').reverse().join('') }}</h2> <!-- 字符串反转 -->
查看vm对象的成员
取属性,都要加$
调数据属性,不用$
在浏览器中可以在 console.log通过 vm对象可以直接访问el和data属性,甚至可以访问data里面的数据
console.log(vm.KaTeX parse error: Expected 'EOF', got '#' at position 9: el) #̲ #box vm对象可以控制…data); # vm对象要显示到页面中的数据
console.log(vm.message);# 这个 message就是data里面声明的数据,也可以使用 vm.变量名显示其他数据,message只是举例.
vue.js的M-V-VM思想
MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式。
Model
指代的就是vue对象的data属性里面的数据。这里的数据要显示到页面中。
View 指代的就是vue中数据要显示的HTML页面,在vue中,也称之为“视图模板” 。
ViewModel 指代的是vue.js中我们编写代码时的vm对象了,它是vue.js的核心,负责连接 View 和 Model,保证视图和数据的一致性,通过双向数据绑定来实现视图与模型的自动同步的.
所以前面代码中,data里面的数据被显示中p标签中就是vm对象自动完成的。
优秀的前端框架vue,原理剖析与实战技巧总结【干货满满】(二):https://developer.aliyun.com/article/1497236