HTML(5)+CSS(3)+JavaScript(ES5、ES6):编写一个个的页面 -> 给后端(PHP、Python、Go、Java) -> 后端嵌入模板语法 -> 后端渲染完数据 -> 返回数据给前端 -> 在浏览器中查看
Ajax的出现 -> 后台发送异步请求,Render+Ajax混合
单用Ajax(加载数据,DOM渲染页面):前后端分离的雏形
Angular框架的出现(1个JS框架):出现了“前端工程化”的概念(前端也是1个工程、1个项目)
React、Vue框架:当下最火的2个前端框架(Vue:国人喜欢用,React:外国人喜欢用)
移动开发(Android+IOS) + Web(Web+微信小程序+支付宝小程序) + 桌面开发(Windows桌面):前端 -> 大前端
一套代码在各个平台运行(大前端):谷歌Flutter(Dart语言:和Java很像)可以运行在IOS、Android、PC端
在Vue框架的基础性上 uni-app:一套编码 编到10个平台
详细的发展史:https://zhuanlan.zhihu.com/p/337276087?utm_source=wechat_session&utm_medium=social&utm_oi=41967790587904
Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架
与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用
Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合
可以一点一点地使用它,只用一部分,也可以整个工程都使用它
Vue官网:https://cn.vuejs.org/
容易上手,通过 HTML、CSS、JavaScript构建应用
灵活
不断繁荣的生态系统,可以在一个库和一套完整框架之间自如伸缩。
高效
20kB min+gzip 运行大小
超快虚拟 DOM
最省心的优化
版本:
1.X:使用较少
2.X: 使用人较多
3.X: 出了很久,公司新项目会选择
注:语法有差距,但是Vue3完全兼容Vue2,可以在Vue3上写Vue2,但是官方不建议了
MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,是一种事件驱动编程方式
类似于DTL中的include,每一个组件的内容都可以被替换和复用
只需要1个页面,结合组件化开发来替换页面中的内容,页面的切换只是组件的替换,页面还是只有1个index.html
CDN的方式引入
<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.7.0/vue.js"></script>
下载后导入
其实就是直接在浏览器中打开https://cdn.jsdelivr.net/npm/vue/dist/vue.js,然后复制下来,创建一个js文件再粘贴进去
<script src="js/vue.js"></script>=
js就是一门解释型语言,只不过js解释器被集成到了浏览器中,所以在浏览器的Console中输入命令,就和在cmd中输入python后,进入交互式环境一样
把chrome的v8引擎(解释器),安装到操作系统之上
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="js/vue.js"></script>
</head>
<body>
<div id="vid">
<h1>{{name}}</h1>
<h1>{{age}}</h1>
</div>
</body>
<script>
new Vue({
el:'#vid', // 这里管理了那个标签
data:{ // 数据
name:'hello world',
age:'18',
},
})
</script>
</html>
语法:{{ 变量、js语法、三目表达式 }}
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>插值title>
<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
<ul>
<li>字符串:{{name}}li>
<li>数值:{{age}}li>
<li>数组:{{list1}}li>
<li>对象:{{obj1}}li>
<li>字符串:{{link1}}li>
<li>运算:{{10+20+30+40}}li>
<li>三目运算符:{{10>20?'是':'否'}}li>
ul>
div>
body>
<script>
let vm = new Vue({
el: '#box', // 在box这个div中可以写 vue的语法
data: {
name: 'Darker', // 字符串
age: 18, // 数值
list1: [1,2,3,4], // 数组
obj1: {name: 'Darker', age: 19}, // 对象
link1: '百度一下 你就知道'
}
})
script>
html>
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Documenttitle>
<script src="./js/vue.js">script>
head>
<body>
<div id="vid">
<h3>v-text:引号中放跟之前插值放的一样h3>
<p v-text="v">p>
<hr>
<h3>v-html:引号中放的跟之前插值放的一样,但是能把标签渲染h3>
<p v-html="h">p>
<hr>
<h3>v-show:控制标签显示与否,没有删除标签,只是隐藏:display:noneh3>
<img src="./img/1.jpg" v-show="show" style="width:50px;height:50px;border:1px solid black;">
<hr>
<h3>v-if:控制标签显示与否 直接把标签删除h3>
<img src="./img/2.jpg" v-if="if_show" style="width:50px;height:50px;border:1px solid black;">
div>
body>
<script>
var vm = new Vue({
el:'#vid',
data:{
h:'点我看美女',
show:true,
if_show:true,
},
})
script>
html>
事件指令是指:点击事件/双击事件/滑动事件,最常用的是点击事件click
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Documenttitle>
<script src="./js/vue.js">script>
head>
<body>
<div id="vid">
<h1>-----图像消失-----h1>
<button @click="showhidden" style="cursor:pointer" title="点点试试看?">点击消失button>
<p>
<span v-if="show">
<img src="./img/1.jpg" style="width:100px;height:100px;border-radius:50%;">
span>
<p>
<h3>事件指令之参数问题:正常有几个参数就传几个参数即可(前端无论多传或少传都不会报错)h3>
<button @click="first()">函数需要参数,但是没传,默认会把event事件传入button>
<p>
<button @click="second('jack',18)">函数需要参数,但是多传了,多传的不会接收button>
<p>
<button @click="third('tom',18)">函数需要几个参数,就传递几个参数button>
div>
body>
<script>
var vm = new Vue({
el:'#vid',
data:{
show:true,
},
methods:{
//事件指令
showhidden:function(){
this.show = !this.show //!取反的意思
console.log(this.show)
},
//事件指令参数问题
first:function(name){
console.log('事件first')
console.log(name)
// alert(name)
},
second:function(name){
console.log('事件second')
console.log('你的名字是:'+name)
// alert('你的名字是:'+name)
},
third:function(name,age){
console.log('事件third')
console.log('你的名字是:'+name+','+'你的年龄是:'+age)
// alert('你的名字是:'+name+','+'你的年龄是:'+age)
}
}
})
script>
html>
事件指令的两种方法:
"v-on:事件名='showhidden'"
<button v-on:click="函数">XXXXbutton>
<button @click="showhidden">XXXXbutton>
方法必须放在methods中
methods: {
showhidden: function () {
this.show = !this.show // ! 取反
}
}
事件指令函数带参数说明:
需要1个,但是没有传,会把事件传入undefined
需要1个,但是传了两个,也只会接收第一个参数
需要2个,传了两个,没问题
语法:v-bind:属性名=“变量名” 可简写成 :属性名=“变量名”
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Documenttitle>
<script src="./js/vue.js">script>
head>
<body>
<div id="vid">
<h1>换图像示例h1>
<button v-on:click="handlerChange" style="cursor:pointer" title="点点试试看?">点击切换button>
<p>
<img v-bind:src="image_change" style="width:100px;height:100px;border-radius:50%;border:1px solid rgb(117, 117, 117);">
div>
body>
<script>
var vm = new Vue({
el:'#vid',
data:{
//属性指令
image_change:'./img/1.jpg',
list:['./img/1.jpg','./img/2.jpg','./img/3.jpg','./img/4.jpg'],
},
//点击事件更换图像
methods:{
//方法一:
handlerChange:function(){
//随机从list中拿出一个值
//统计数组的长度,后取出一个随机数索引0-数组总长度之间的整数
console.log(Math.floor(Math.random()*(this.list.length)))
this.image_change=this.list[Math.floor(Math.random()*(this.list.length))]
}
//方法二:
// handlerChange:function(){
// var c = Math.ceil(Math.random()*4)
// console.log(c)
// this.image_change=`./img/${c}.jpg`
// }
}
})
script>
html>
class:推荐用数组
:class='变量'
变量可以是字符串,数组,对象
style:推荐用对象
:style='变量'
变量可以是字符串,数组,对象
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Documenttitle>
<script src="./js/vue.js">script>
<style>
.background{
background-color:lightblue;
}
.fontsize{
font-size:2em;
}
style>
head>
<body>
<div id='div'>
<h1>class可以绑定的类型h1>
<h3>class-----》字符串形式h3>
<button @click="handlechange1">点击添加属性button>
<p>
<span :class="str_class">加加看?span>
<hr>
<h3>class-----》数组的形式h3>
<button @click="handlechange2">点击添加属性button>
<p>
<span :class="list_class">加加看?span>
<hr>
<h3>class-----》对象的形式h3>
<button @click="handlechange3">点击添加属性button>
<p>
<span :class="obj_class">加加看?span>
<p>
<h1>style可以绑定的类型h1>
<h3>style-----》字符串形式h3>
<button @click="handlechange4">点击添加属性button>
<p>
<span :style="str_style">加加看?span>
<hr>
<h3>style-----》数组的形式h3>
<button @click="handlechange5">点击添加属性button>
<p>
<span :style="list_style">加加看?span>
<hr>
<h3>style-----》对象的形式h3>
<button @click="handlechange6">点击添加属性button>
<p>
<span :style="obj_style">加加看?span>
<hr>
div>
<script>
var div = new Vue({
el:'#div',
data:{
str_class:'background',
list_class:['background'],
obj_class:{'background':true,'fontsize':false},
str_style:'background-color:lightblue',
list_style:[{'background-color':'lightblue'}],
obj_style:{'background-color':'lightblue'},
},
methods:{
handlechange1:function(){
this.str_class=this.str_class+' fontsize'
},
handlechange2:function(){
this.list_class.push('fontsize')
},
handlechange3:function(){
// this.obj_class['fontsize']=true
this.obj_class.fontsize=true
},
handlechange4:function(){
this.str_style=this.str_style+';font-size:2em'
},
handlechange5:function(){
// this.list_style.push({'font-size':'2em'})
//可以不写横杠,直接使用驼峰方式
this.list_style.push({'fontSize':'2em'})
},
handlechange6:function(){
//对象新增的属性,div监控不到,就无法实现响应式
//但是对象中原来有的属性,修改是能监控到的
//this.obj_style['background-color']='red'
//原来对象中没有值的,就能监控到,但是如果
Vue.set(this.obj_style,'font-size','2em')
},
}
})
script>
body>
html>
v-if=条件 放在标签上,如果条件成立,该标签就现实,如果条件不成立,该标签就不显示
v-else-if=条件 放在标签上,如果条件成立,该标签就现实,如果条件不成立,该标签就不显示
v-else 放在标签上,上面条件都不成立,显示这个标签
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Documenttitle>
<script src="../js/vue.js">script>
head>
<body>
<div id="div">
<span v-if="source>=90&&source<=100">优秀span>
<span v-else-if="source>80&&source<90">良好span>
<span v-else-if="source>70&&source<80">一般span>
<span v-else>瑕疵span>
div>
<script>
var div = new Vue({
el:'#div',
data:{
source:99,
}
})
script>
body>
html>