前端框架vue.js系列(1)

vue是一套构建用户界面的渐进式框架,其核心库只关注视图层,通过使用vue手脚架,它完全能够为复杂的单页应用程序提供驱动。为了便于初学者入门vue语法,介绍语法部分均通过引用vue.js文件的方式来引入vue,在实际项目开发中,建议尽量使用vue手脚架开发和npm来维护。

渐进式框架

那么,什么叫渐进式框架?渐进式框架可以理解为能支持任何其他前端框架及类库的一种框架。这就意味着vue框架没有任何结构上的主张,比如AngularJs前端框架对元素的控制必须用控制器controller。从另一个角度来说,vue可以兼容现在乃至未来任何的前端用户界面技术,这就是vue的强大之处。

约定

本系列文章demo均以当前vue最新版本2.4.2为准,所有知识点都来自于vue官网及博主个人实际使用经验的总结而来,目的是为了让更多的前端开发人员能更迅速的掌握使用vue框架,本篇主要简单介绍一下vue的基本用法和语法,我们来创建第一个vue应用:hello world。


<!DOCTYPE html>
<html>
 
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script type="text/javascript" src="./js/libs/vue/2.4.2/vue.js"></script>
	</head>
 
	<body>
		<!-- helloworld -->
		<div id="app">
			{{message}}
		</div>
		<script>
			var app = new Vue({
				el: "#app",
				data: {
					message: "hello world"
				}
			});
		</script>
	</body>
 
</html>

上例中new Vue()表示创建一个实例,el表示该实例绑定的元素id,data表示数据内容,数据格式为对象类型。在元素标签中用两个大挂弧{{…}}表示的是数据输出(这种写法源于react的jsx表达式),上例中{{message}}将输出为文本hello world。

另外vue常用的几个指令有:v-bind绑定,v-if条件,v-for循环,v-on监听,v-model双向绑定,Vue.component()创建组件,这些指令在本篇中大家不必深究,在这里为了让大家对vue指令有一个基本的认知,demo如下:

<!DOCTYPE html>
<html>
 
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script type="text/javascript" src="./js/libs/vue/2.4.2/vue.js"></script>
	</head>
 
	<body>
		<!-- helloworld -->
		<div id="app">
			{{message}}
		</div>
		<script>
			var app = new Vue({
				el: "#app",
				data: {
					message: "hello world"
				}
			});
		</script>
		<!-- v-指令 -->
		<div id="app2">
			<span v-bind:title="message">鼠标悬停几秒钟查看此处动态绑定的提示信息!</span>
		</div>
		<script>
			var app2 = new Vue({
				el: "#app2",
				data: {
					message: '页面加载于 ' + new Date().toLocaleString()
				}
			});
		</script>
		<!-- 条件 -->
		<div id="app3">
			<span v-if="seen">现在你看见我了,但两秒后我消失了</span>
		</div>
		<script>
			var app3 = new Vue({
				el: "#app3",
				data: {
					seen: true
				}
			});
			setTimeout(function() {
				app3.seen = false;
			}, 2000);
		</script>
		<!-- 循环 -->
		<div id="app4">
			<ol>
				<li v-for="item in items">{{item}}</li>
			</ol>
		</div>
		<script>
			var app4 = new Vue({
				el: "#app4",
				data: {
					items: ["a", "b", "c"]
				}
			});
		</script>
		<!-- 监听 -->
		<div id="app5">
			<span>{{message}}</span>
			<button v-on:click="resetMsg(helloworld);">改变文本</button>
		</div>
		<script>
			var app5 = new Vue({
				el: "#app5",
				data: {
					message: "!!!!!!"
				},
				methods: {
					resetMsg: function(resp) {
						this.message = resp;
					}
				}
			});
		</script>
		<!-- v-model双向绑定 -->
		<div id="app6">
			<p>{{message}}</p>
			<input type="text" v-model="message" />
		</div>
		<script>
			var app6 = new Vue({
				el: "#app6",
				data: {
					message: "helloworld"
				}
			});
		</script>
		<!-- 组件component -->
		<div id="app7">
			<ol>
				<my-li v-for="item in items" v-bind:todo="item" v-bind:key="item.id"></my-li>
			</ol>
		</div>
		<script>
			Vue.component("my-li", {
				props: ['todo'], // 获取绑定的属性值
				template: "<li>{{todo.text}}</li>"
			});
			var app7 = new Vue({
				el: "#app7",
				data: {
					items: [{
							id: 0,
							text: '蔬菜'
						}, {
							id: 1,
							text: '奶酪'
						},
						{
							id: 2,
							text: '随便其他什么人吃的东西'
						}
					]
				}
			});
		</script>
	</body>
 
</html>

完整vue实例结构


var vue = new Vue({
	el: "",
	data: {},
	methods: {},
	filters: {},
	computed: {},
	components: {},
	watch: {}
});

建议要熟悉vue语法及vue实例结构,因为这些将有助于你快速建立vue实例。
el
绑定指定ID的元素标签并挂载在该Dom节点
data
定义了作用域在该vue实例的变量
methods
执行的方法函数
filters
通过vue实例的filters属性创建过滤器,创建的过滤器是一个函数,在值运算中用竖杠 | 表示
computed
通过vue实例的computed属性创建计算器,创建的计算器是一个函数,计算器会依赖于绑定的data而更新,如本例num更新,addOne也会更新。与过滤器和methods功能类似,不同的是若计算器依赖的数值不变,则不会重新执行函数,性能较优。
components
组件
watch
监察数据的变化。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值