vuejs教程 笔记(一)

  

一. 邂逅Vuejs

1.1(理解)Vuejs的认识和特点介绍

三大主流框:

  1. Vuejs
  2. React
  3. Angular Js

Vue (读音 /vju?/,类似于 view)
Vue是一个渐进式的框架

  • 渐进式意味着你可以将Vue作为你应用的一部分嵌入其中,带来更丰富的交互体验
    或者如果你希望将更多的业务逻辑使用Vue实现,那么Vue的核心库及其生态系统
    比如Core+Vue-router+Vuex,也可以满足各种各样的需求
  • Vue有很多特点和Web开发中常见的高级功能
    1. 解耦试图和数据
    2. 可复用的组件
    3. 前端路由技术
    4. 状态管理
    5. 虚拟DOM

具备一定HTTM、CSS、JavaScript基础
Es6

1.2(掌握)Vuejs的安装方式

方式一:直接CDN引入(可以选择引入开发环境版本还是生产环境版本)

< !- - 开发环境版本,包含了有帮助的命令行警告 - - >
	<script src = “https://cdn.jsdelivr.net/npm/veu/dist/vue.js”></script>
<! - - 生产环境版本,优化了尺寸和速度 - ->
	<script src = https://cdn.jsdelivr.net/npm/vue></script>

方式二:下载和引入

开发环境:https://vuejs.org/js/vue.js
生产环境:https://vuejs.org/js/vue.min.js

方式三:NPM安装

后续通过webpack和CLID 的使用,我们使用该方式

https://vuejs.org/v2/guide/installation.html
不要点击下载,右键链接另存为
这样就有下载下来了一个vue.js文件

vscode
webstrom

1.3 Vue的初体验

  • hello Vuejs
    • mustache->体验vue响应式
  • Vue列表展示
    • v-for
    • 后面给数组追加元素的时候,新的元素也可以在界面中渲染出来
  • Vue计数器案例
    • 事件监听:click->methods

响应式,当数据改变时,界面会自动改变,可以打开开发者模式console测试

创建Vue对象时,传入了一些options:{}

  • el属性:该属性决定了这个vue对象挂载到哪一个元素上
  • data属性:该属性中通常会存储一些数据
    • 这些数据可以是我们直接定义出来的
    • 也可以来自网络,从服务器加载的

新的指令@click v-on:click
新的属性: methods 该属性用于在Vue对象中定义方法

1.4 Vue中的MVVM

Vue中的MVVM(维基百科)
MVVM(Model-view-viewmodel)是一种软件架构模式。

Data Bindings 数据绑定

1.5 创建Vue实例传入的options

1. el:
		类型:string | HTMLElement
		作用:决定以后Vue实例会管理哪一个DOM
2. data
		类型:Object | Function(组件当中必须是一个函数)
		作用:Vue实例对应的数据对象
3. methods
		类型:{[key:string] : Function}
		作用:定义属于Vue的一些方法,可以在其他地方调用,也可以在指令中使用
4. 生命周期函数

开发中什么时候称为方法,什么时候称为函数

  • 方法:method
  • 函数:function
  • 写在外面 函数
  • 定义在类中 方法(一般和实例挂钩)

GitHub -> tag

  • release 测试过的稳定版本

代码规范:缩进4个空格

  • 2个空格 CLI ->editconfig 2个空格

模板template

  • hbuilder 工具 - >代码块设置(看文档说明)

二 . 插值语法

  • Mustache{{}} - 双大括号
    Mustache:胡子/胡须
  • v-once
  • v-html
  • v-text
  • v-pre:{{}}
  • v-cloak:斗篷
<div id = "app">
	<h2>{{firstName + lastName}}</h2>
	<h2>{{firstName + " " + lastName}}</h2>
	<h2>{{firstName}} {{lastName}}</h2>
	<h2>{{counter * 2}}</h2>

</div>
  • v-once
  • v-html
  • v-text
  • v-pre 原封不动输出,不解析
  • v-clock
<style>
	[v-cloak]{
		display:none;
	}
</style>

<div id = "app" v-cloak>
	<h2 v-once>{{message}}</h2>
	<h2 v-text="message"></h2>	//不太用,会覆盖
	<h2>{{url}}</h2>
	<h2 v-html="url"></h2>
	<h2 v-pre>{{url}}</h2>	
	
</div>
<script>
	//在vue解析之前,div中有一个属性v-cloak
	//在vue解析之后,div中没有属性v-cloak
	const app = new Vue({
		el:"#app",
		data:{
			message:"hello",
			url:'<a href="http://www.baidu.com">百度一下</a>
		}
	})
	//setTimeout(function(){},1000);
</script>

三 . 绑定属性 v-bind

3.1 v-bind动态绑定基本属性

  • v-bind:src
  • :href

3.2 v-bind动态绑定class

  • 对象语法:练习:class=’{类名:boolean}’
  • 数组语法

3.3 v-bind动态绑定style

  • 对象语法
  • 数组语法

四 . 计算属性

  • 案例一:firstName+lastName
  • 案例二:books -> price

methods和computed看起来都可以实现我们的功能
为什么还要多一个计算属性这个东西
计算属性会进行缓存,如果多次使用时,计算属性只会调用一次

相关文章