Vue之前端的发展史、介绍 和 基本使用、第一个helloworld、插值语法、文本指令、事件指令
一、前端的发展史
-
1 HTML(5)、CSS(3)、JavaScript(ES5、ES6):编写一个个的页面 -> 给后端(PHP、Python、Go、Java) -> 后端嵌入模板语法 -> 后端渲染完数据 -> 返回数据给前端 -> 在浏览器中查看
-javascript=ECMAScript(5,6,13) + Dom + Bom -
2 Ajax的出现 -> 后台发送异步请求,Render+Ajax混合
-异步JavaScript和XML
-咱们学的是jq的ajax函数 -
3 单用Ajax(加载数据,DOM渲染页面):前后端分离的雏形
-
4 Angular框架的出现(1个JS框架):出现了“前端工程化”的概念(前端也是1个工程、1个项目)
-
5 React、Vue框架:当下最火的2个前端框架(Vue:国人喜欢用,React:外国人喜欢用)
-
6 移动开发(Android+IOS) + Web(Web+微信小程序+支付宝小程序) + 桌面开发(Windows桌面):前端 -> 大前端
-
7 一套代码在各个平台运行(大前端):谷歌Flutter(Dart语言:和Java很像)可以运行在IOS、Android、PC端
-
8 在Vue框架的基础性上 uni-app:一套编码 编到10个平台
-
9 在不久的将来 ,前端框架可能会一统天下
二、Vue介绍 和 基本使用
Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式js框架
与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用
Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合
M-V-VM思想:
MVVM 是Model(数据)-View(视图)-ViewModel(vm) 的缩写,它是一种基于前端开发的架构模式,是一种事件驱动编程方式
-model:前端的数据,在js中,js的变了
-view:我们看到的,css,html
-vm:负责,只要js数据变了,view页面就发生变化,只要页面发生变化,js变量就跟着变
MTV,MVC,MVP,MVVM
组件化开发、单页面开发(单页面应用:spa)
版本
-最新:vue4,没有公司在用
-公司主流:新项目基本会有Vue3,老项目继续用vue2
-咱们都讲
学的是vue2:文档地址:https://v2.cn.vuejs.org/v2/guide/
vue3的文档:https://cn.vuejs.org/guide/essentials/application.html
响应式的
数据(js)和 DOM (页面)已经被建立了关联,所有东西都是响应式的
补充: 解释型的语言是需要解释器的
js就是一门解释型语言,只不过js解释器被集成到了浏览器中
所以,在浏览器的Console中输入命令,就和在cmd中输入python后,进入交互式环境一样
nodejs:一门后端语言
把chrome的v8引擎(解释器),安装到操作系统之上
三、Vue之第一个helloworld
编辑器的选择
-python---》Pycharm
-前端:
webstorm:(jetbrains公司的,使用习惯跟Pycharm)
vscode:免费
Sublime Text
vim
-我选择使用Pycharm,它就是webstorm
下载
https://cdn.jsdelivr.net/npm/vue/dist/vue.js
代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script src="./vue/vue.js"></script>
<title>Title</title>
</head>
<body>
<div id="app">
{{ message }}
<span ></span>
</div>
</body>
<script>
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
</script>
</html>
四、插值语法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
<p>字符串:{{name}}</p>
<p>数字:{{age}}</p>
<p>数组:{{hobby}}--->{{hobby[1]}}</p>
<p>对象:{{wife}}--->{{wife['name']}}---->{{wife.age}}</p>
<p>标签形式字符串:{{a}}--->说明不存在xss攻击</p>
<p>-----插值语法,还可以放,简单表达式和函数(后面了)-----</p>
<p>简单表达是:{{1 + 1}}</p>
<p>三目运算符【条件?符合条件执行这个:不符合条件】:{{10>2?'正确':'不正确'}}</p>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
name: 'lqz',
age: 19,
hobby: ['篮球', '足球', 'spa'], // js 就叫数组
wife: {name: '刘亦菲', age: 38}, // js 中叫对象
a: '<a href="http://www.baidu.com">点我看美女</a>' // 标签形式字符串
}
})
</script>
</html>
四、 文本指令
指令 | 释义 |
---|---|
v-html | 让HTML渲染成页面 |
v-text | 标签内容显示js变量对应的值 |
v-show | 放1个布尔值:为真 标签就显示;为假 标签就不显示 |
v-if | 放1个布尔值:为真 标签就显示;为假 标签就不显示 |
指令系统: 写在标签上,v-开头的 标签,称之为指令,每个指令都有特殊用途
v-指令名='写原来插值能写的东西'
v-指令名='name' # 变量
v-show 与 v-if 的区别:
- v-show:标签还在,只是不显示了(display: none)
- v-if:直接操作DOM,删除/插入 标签
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
文本指令之 v-text,把变量渲染在标签内部:<span v-text="a"></span>
<br>
插值语法:<span>{{a}}</span>
<br>
文本指令之v-html,把标签类型的字符串直接渲染成标签:<span v-html="a"></span>
<h2>v-if的使用,只能写条件,或布尔类型的变量</h2>
<div v-if="is_show">
我是个div---v-if的使用
</div>
<br>
<h2>v-show的使用</h2>
<div v-show="is_show">
我是个div---v-show的使用
</div>
<br>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
a: '<a href="http://www.baidu.com">点我看美女</a>', // 标签形式字符串
is_show: false,
}
})
</script>
</html>
五、事件指令
用的最多的就是点击click事件,给某个标签绑定一个点击事件,当点击一下,就执行某个函数
使用方式
v-on:事件名='函数名'
重点:v-on:事件='函数名'
可以简写成:
@事件='函数名'
指令 | 释义 |
---|---|
v-on | 触发事件(不推荐) |
@ | 触发事件(推荐) |
@[event] | 触发event事件(可以是其他任意事件) |
代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./vue/vue.js"></script>
</head>
<body>
<div id="app">
<button v-on:click="handleClick">点我看美女</button>
<br>
<button v-on:click="handleClick2">点我看帅哥</button>
<h1>点击,显示和隐藏美女图片</h1>
<button @click="handleShow">点我看真美女</button>
<br>
<img :src="img" alt="" height="500px" v-if="is_show">
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
is_show: true,
img:'https://img1.baidu.com/it/u=3410523613,2628462258&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=666'
}, // data配置项中,放数据,变量
methods: {
// 用的少
// 'handleClick': function () {
// alert('美女')
// },
// 'handleClick2': function () {
// alert('帅哥')
// },
// 以后都用这种
handleClick() {
alert('美女')
},
handleClick2() {
alert('帅哥')
},
handleShow() {
// data中定义的,用this取
this.is_show = !this.is_show
},
}
})
// es6 的对象简写形式
// var d={'name':'lqz','age':19}
// var d = {name: 'lqz', age: 19} // 简写成
var name = 'lqz'
var age = 19
// var f=function (){
// alert('帅哥')
// }
// var d = {name: name, age: age,f} // 简写成 这个
// var d = {name, age,f(){}} // 简写成 最终 等同于{name: name, age: age,f:function (){}}
// console.log(d)
</script>
</html>