前言
提示:这里可以添加本文要记录的大概内容:
例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。
提示:以下是本篇文章正文内容,下面案例可供参考
初识Vue.js
Vue.js介绍
一、MVVM模式介绍
Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的。相比于Angular.js,Vue.js提供了更加简洁、更易于理解的API,使得我们能够快速地上手并使用Vue.js。
如果你之前已经习惯了用jQuery操作DOM,学习Vue.js时请先抛开手动操作DOM的思维,因为Vue.js是数据驱动的,你无需手动操作DOM。它通过一些特殊的HTML语法,将DOM和数据绑定起来。一旦你创建了绑定,DOM将和数据保持同步,每当变更了数据,DOM也会相应地更新。
当然了,在使用Vue.js时,你也可以结合其他库一起使用,比如jQuery。
下图不仅概括了MVVM模式(Model-View-ViewModel),还描述了在Vue.js中ViewModel是如何和View以及Model进行交互的。
ViewModel是Vue.js的核心,它是一个Vue实例。Vue实例是作用于某一个HTML元素上的,这个元素可以是HTML的body元素,也可以是指定了id的某个元素。
当创建了ViewModel后,双向绑定是如何达成的呢?
首先,我们将上图中的DOM Listeners
和Data Bindings
看作两个工具,它们是实现双向绑定的关键。
从View侧看,ViewModel
中的DOM Listeners
工具会帮我们监测页面上DOM元素的变化,如果有变化,则更改Model中的数据;
从Model侧看,当我们更新Model中的数据时,Data Bindings
工具会帮我们更新页面中的DOM元素。
二、单页面组件介绍及案例讲解
文件扩展名为 .vue
的 single-file components (单文件组件) 为前端项目开发中遇到的一系列问题提供了解决方法。
这是一个文件名为 Hello.vue
的简单实例:
<template>
<!-- 模板,存放HTML标签 -->
</template>
<script>
// Js 代码
export default {
name: "Hello"
}
</script>
<style>
/* css样式 */
</style>
三、插值表达式介绍及案例讲解
数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插值:
<template>
<span>Message:{{msg}} </span>
</template>
<script>
export default {
name: "Hello",
data() {
return {
msg: "Hello World",
};
},
};
</script>
Mustache 标签将会被替代为对应数据对象上 msg
property 的值。无论何时,绑定的数据对象上 msg
property 发生了改变,插值处的内容都会更新。
迄今为止,在我们的模板中,我们一直都只绑定简单的 property 键值。但实际上,对于所有的数据绑定,Vue.js 都提供了完全的 JavaScript 表达式支持。
{{ number + 1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('') }}
<div v-bind:id="'list-' + id"></div>
这些表达式会在所属 Vue 实例的数据作用域下作为 JavaScript 被解析。有个限制就是,每个绑定都只能包含单个表达式,所以下面的例子都不会生效。
<!-- 这是语句,不是表达式 -->
{{ var a = 1 }}
<!-- 流控制也不会生效,请使用三元表达式 -->
{{ if (ok) { return message } }}
数据渲染
一、v-text指令介绍及案例讲解
v-text指令用于将数据填充到标签中,作用与插值表达式类似,但是没有闪烁问题:
<template>
<span v-text="msg"></span>
</template>
<script>
export default {
name: "Hello",
data() {
return {
msg: "Hello World",
};
},
};
</script>
二、v-html指令介绍及案例讲解
双大括号会将数据解释为普通文本,而非 HTML 代码。为了输出真正的 HTML,你需要使用 v-html
指令:
<template>
<span v-html="msg"></span>
</template>
<script>
export default {
name: "Hello",
data() {
return {
msg: "<h1>Hello World</h1>",
};
},
};
</script>
你的站点上动态渲染的任意 HTML 可能会非常危险,因为它很容易导致 XSS 攻击。请只对可信内容使用 HTML 插值,绝不要对用户提供的内容使用插值。
三、v-if介绍及案例讲解
v-if
指令用于条件性的渲染一块内容。这块内容只会在指令的表达式返回 true
值的时候渲染
<template>
<div id="app">
<p v-if="is_show">这是一个p标签</p>
<p v-if="is_have">我也是一个p标签</p>
</div>
</template>
<script>
export default {
data(){
return{
is_show: true,
is_have: false
}
}
}
</script>
- 在
JavaScript
中,true
(真值)指的是在布尔值上下文中,转换后的值为真的值。 - 所有值都是真值,除非它们被定义为 假值(即除 false、0、“”、null、undefined 和 NaN 以外皆为真值)
案例:动态切换内容
<template>
<div id="app">
<input type="radio" name="gender" value="男" v-model="msg">男
<input type="radio" name="gender" value="女" v-model="msg">女
<input type="radio" name="gender" value="人妖" v-model="msg">人妖
<input type="radio" name="gender" value="保密" v-model="msg">保密
<h2 v-if="msg == '女'">你是一个Girl</h2>
<h2 v-else-if="msg == '男'">你是一个Boy</h2>
<h2 v-else-if="msg == '人妖'">你是一个LadyBoy</h2>
<h2 v-else>你是一个神秘的人</h2>
</div>
</template>
<script>
export default {
data(){
return{
msg: "保密",
}
}
}
</script>
四、v-show介绍及案例讲解
v-show
和v-if
的用法和效果看起来是一样的
<template>
<div id="app">
<input type="button" value="点击" @click="btn">
<h2 v-show="a">嗨,我在</h2>
</div>
</template>
<script>
export default {
data(){
return{
a: true
}
},
methods:{
btn(){
this.a = !this.a
}
}
}
</script>
v-if和v-show异同介绍
v-if
是控制元素是否在DOM
渲染,实现显示和隐藏v-show
是控制元素的CSS
属性display
,实现显示和隐藏
v-for
一、v-for介绍及案例讲解
- v-for 可以循环遍历数据,并渲染出多个标签
- 在v-for指令操作里 a in b是必要格式
- v-for 可以循环遍历数据,并渲染出多个标签
<div id="app">
<p v-for="i in 8">
{{i}}
</p>
</div>
在v-for指令操作里 a in b是必要格式
v-for 可以循环遍历数据,并渲染出多个标签
二、循环数组介绍及案例讲解
- 遍历数组时,i 是数组中的值,k 是索引
遍历数组介绍及案例讲解 ★★★★
<template>
<div id="app">
<p v-for="(i, k) in list_">
{{i}} {{k}}
</p>
</div>
</template>
<script>
export default {
data(){
return{
list_: [2,4,6,8,10]
}
}
}
</script>
三、循环对象介绍及案例讲解
v-for
支持最多三个参数,同时获取遍历对象的key
和value
值,以及index
索引位置要注意的是,此时的key
和value
和python中的顺序是颠倒的,key
在后,value
在前
v-for
支持最多三个参数,同时获取遍历对象的key
和value
值,以及index
索引位置
要注意的是,此时的key
和value
和python中的顺序是颠倒的,key
在后,value
在前
<template>
<div id="app">
<p v-for="(value, key, i) in user">
{{i}}--{{key}}--{{value}}
</p>
</div>
</template>
<script>
export default {
data(){
return{
user: {
name: "张三",
age: 18
}
}
}
}
</script>
v-on
一、v-on介绍及案例讲解
v-on
给元素绑定对应事件,可以缩写为@
<template>
<div>
<! -- <button v-on:click="btn">弹框</button> -->
<!-- 效果和上面等同 -->
<button @click="btn">弹框</button>
</button>
</div>
</template>
<script>
export default {
methods:{
btn(){
alert(111)
}
}
}
</script>
二、事件修饰符介绍与案例讲解
1、阻止冒泡 .stop介绍及案例讲解
比如一个按钮在一个div中,并且按钮和div均有自己的事件,那么此时点击按钮,事件会像冒泡一样从按钮开始一直到div进行触发,
.stop`用来阻止默认的事件触发行为
<template>
<div id="app">
<p @click="pClick">
<input type="button" value="按钮" @click.stop="btnClick">
</p>
</div>
</template>
<script>
export default {
methods:{
pClick() {
console.log("p点击被触发了")
},
btnClick() {
console.log("按钮点击被触发了")
}
}
}
</script>
2、阻止默认 .prevent介绍及案例讲解
- 比如像a标签这样的,在点击时他有默认的跳转动作,可以通过
.prevent
阻止该默认行为
<template>
<div id="app">
<a v-bind:href="url" :id="msg + '123'" @click.prevent="aClick">百度 </a>
</div>
</template>
<script>
export default {
name: 'one',
data(){
return{
url: "http://www.baidu.com",
msg:"bd"
}
},
methods:{
aClick(){
console.log("链接被点击啦")
}
}
}
</script>
3、捕获事件 .capture介绍及案例讲解
-
默认的事件触发处理机制是冒泡机制,通过
.capture
即可将冒泡顺序从里向外,颠倒顺序 -
也可理解为在冒泡机制中,谁有该修饰符,先触发谁的事件
<template>
<div id="app">
<p @click.capture="pClick">
<input type="button" value="按钮" @click="btnClick">
</p>
</div>
</template>
<script>
export default {
name: 'one',
data(){
return{
msg:'hello'
}
},
methods:{
pClick() {
console.log("p点击被触发了")
},
btnClick() {
console.log("按钮点击被触发了")
}
}
}
</script>
4、 自身事件 .self介绍及案例讲解
-
与capture和冒泡不同,
.self
只有是自身触发的当前的事件才真正执行处理的回调函数 -
并且.self只会阻止当前元素的事件触发行为
<template>
<div @click="divClick" class="div1">
<p @click.self="pClick" class="p1">
<input type="button" value="按钮" @click="btnClick">
</p>
</div>
</template>
<script>
export default {
name: 'one',
data(){
return{
msg:'hello'
}
},
methods:{
divClick() {
console.log("盒子点击被触发了")
},
pClick() {
console.log("p点击被触发了")
},
btnClick() {
console.log("按钮点击被触发了")
}
}
}
</script>
5、 单次事件 .once介绍及案例讲解
- 使用
.once
只触发一次事件函数
<template>
<div id="app">
<input type="button" value="提交" @click.once="btn">
</div>
</template>
<script>
export default {
name: 'one',
data(){
return{
msg:'hello'
}
},
methods:{
btn(){
alert(1111)
}
}
}
</script>
总结
1.了解MVVM开发模式
2.掌握Vue实例对象构造
3.掌握页面数据渲染
3.掌握v-for、v-on