说说 Vue.js 实例及数据绑定能力

1 创建实例

通过 Vue() 构造函数就可以创建一个 Vue 的根实例:

var app = new Vue({
  ...
});
复制代码

1.1 el 选项

el 选项用于绑定页面中的某个 DOM 元素。它可以是 HTMLElement 或是 CSS 选择器。

在上例中:

  • HTMLElement 方式为 document.getElementById('app')
  • CSS 选择器方式为 #app

建议使用 CSS 选择器方式,因为它更简洁。

可以通过 app.$el 来访问这个 DOM 元素。

1.2 data 选项

data 选项用于设定需要双向绑定的数据。建议把所有会用到的数据都放在 data 选项,这样做便于维护。

通过 Vue 实例,我们可以U获取 data 对象中的所有属性对象:

html:

"app">
复制代码

js:

var app = new Vue({
	el: '#app',
	data: {
		content: '今天天气不错'
	}
});
console.log("content:" + app.content);//今天天气不错
复制代码

我们也可以在 data 选项中指向一个已定义的变量,这样它们之间就建立了双向绑定关系,即修改其中一个值时,另一个的值也会发生变化:

var news = {
	title: '火车票购票新规:换乘购票需间隔40分钟以上'
};
var app3 = new Vue({
	el: '#app',
	data: news
});
console.log('app3.title:' + app3.title);//火车票购票新规:换乘购票需间隔40分钟以上

//修改 Vue 实例属性
app3.title = '菜鸟驿站数据被盗';
console.log('news.title:' + news.title);//菜鸟驿站数据被盗

//修改变量属性
news.title = '央视中秋晚会节目单公布 吉隆坡悉尼海外分会场成亮点';
console.log('app3.title:' + app3.title);//央视中秋晚会节目单公布 吉隆坡悉尼海外分会场成亮点
复制代码

2 生命周期

创建实例时,会经历一系列的初始化过程,同时也会调用相应的生命周期中的钩子。我们可以在合适的时机,在这些钩子中执行某些特定的业务。

常用的生命周期钩子有这些:

钩子 说明
created 实例化创建完成后调用,此阶段完成了数据观测,但尚未挂载, $el 还不可用,一般在此进行一些数据初始化处理工作。
mounted el 挂载到实例后调用,一般在此编写第一个业务逻辑 。
beforeDestroy 实例被销毁之前调用 。 一般在此解绑通过 addEventListener 添加的监听事件。

**注意:**钩子中的 this 指向它自身的 Vue 实例。

var app4 = new Vue({
	el: '#app',
	data: {
		name:'deniro'
	},
	created:function () {
		console.log(this.name);//deniro
	},
	mounted:function () {
		console.log(this.$el);//
"app">
} }); 复制代码

3 插值与表达式

插值语法是双大括号( Mustache 语法) “{{ }}”,它会自动将我们双向绑定的数据实时显示出来。

html:

"app"> {{friend}}
复制代码

js:

var app = new Vue({
	el: '#app',
	data: {
		friend: 'Jack'
	}
})
复制代码

双大括号 {{friend}} 会被替换为 Jack。

只要数据被修改,那么文本插值中的内容都会被替换。我们做一个计数器,它的值每秒会递增 1:

html:

"app2"> {{count}}
复制代码

js:

var app2 = new Vue({
	el: '#app2',
	data: {
		count: 1
	},
	mounted: function () {
		var that = this;//设置 that 为当前 Vue 实例

		//每秒递增计数器
		this.timer = setInterval(function () {
			that.count++;//递增
		}, 1000);
	},
	beforeDestroy: function () {//销毁前,清除定时器
		if (this.timer) {
			clearInterval(this.timer);
		}
	}
});
复制代码

效果:

插值表达式还支持使用 JavaScript 表达式进行简单的运算 、 甚至支持三元运算符。

html:

"app5"> {{num*3}} {{isTrue?'真的':'假的'}} {{context.length}}
复制代码

js:

var app5 = new Vue({
	el: '#app5',
	data: {
		num: 3,
		isTrue: true,
		context: '听轻音乐是一种享受O(∩_∩)O~'
	}
});
复制代码

输出结果:

9 真的 17

注意: Vue 只支持单个表达式,不支持语句和流程控制 。 另外,在表达式中,不能使用用户自定义的全局变量,只能使用 Vue 内部定义全局变量,如 Math 和 Date 等。

4 输出 HTML 代码

可以使用 v-html 属性,让某个 HTML 元素内包裹 HTML 代码:

html:

"app3"> "h1">
复制代码

js:

var app3 = new Vue({
	el: '#app3',
	data: {
		h1: '

据说用牙刷刷猫时,猫会感觉像被妈妈舔一样,网友试了下结果……

'
} }); 复制代码

**注意:**用户输入的内容,如果直接使用 v-html 属性输出 HTML 代码,那么就有可能遭遇 XSS 攻击的问题,所以服务端必须对用户提交的内容进行过滤处理(如转义尖括号 <>)。

5 v-pre 属性

可以使用 v-pre 属性,来跳过这个元素与其子元素的编译过程,比如希望显示 {{}} 字符串:

html:

"app4"> {{content}}
复制代码

6 过滤器

Vue.js 支持在 {{ }} 插值的尾部 · 添加一个管道符 “ | ” 实现数据过滤功能,这项能力经常用于格式化文本,比如字母全部大写,格式化货币数值等 。 过滤的规则是自定义的,通过给 Vue 实例添加选项 filter 来设置,假设我们对返回的字符串,设置为全部大写:

html:

"app6"> {{str | upperCaseStr}}
复制代码

js:

var app6 = new Vue({
	el: '#app6',
	data: {
		str: "deniro"
	},
	filters: {
		upperCaseStr: function (val) {
			return val.toUpperCase();
		}
	}
});
复制代码

输出结果:

DENIRO

**注意:**过滤选项名是 filters,有 s 结尾的哦O(∩_∩)O~

过滤器还可以串联起来:

{{ val | filterFuntionA | filterFuntionB | ... }}

因为过滤器是 JavaScript 函数,所以可以定义入参:

{{ val | filterFuntion(arg1,arg2,...)}}

**注意:**入参是从过滤函数的第二个参数开始的,因为第一个是 val。


过滤器适用于处理简单的文本格式化操作,如果需要处理更为复杂的数据转换操作,建议使用计算属性。

你可能感兴趣的:(说说 Vue.js 实例及数据绑定能力)