vue刨坑(二)
vue实例
vue实例
每一个应用都是通过vue这个构造函数创建根实例(root instance),启动 new vue(选项对象)
需要传入选项对象,对象包含挂载元素,数据,模板,方法等。
- el:挂载元素选择器 string|htmlelement
- data:代理数据 object|function
- methods:定义方法 object
vue代理data数据
每个vue实例都会代理其data对象所有的属性,这些被代理的属性是响应的。新添加的属性不具备响应功能,改变后不会更新视图。
vue实例自身属性和方法
暴露自身的属性和方法,已$开头 例如:$el $data
声明式渲染
命令式
需要以具体代码表达在哪里(where)做什么(what),如何实现(how)
声明式
只需要声明在哪里(where)做什么(what),而无需关心如何实现(how)
//eg1:如下为命令式:
var arr=[1,2,3,4];
var newArr=[];
for (var i = 0; i < arr.length; i++) {
newArr.push(arr[i]*2)
}
console.log(newArr);//2,4,6,8
//eg2:如下为声明式
var arr=[1,2,3,4,5];
var newArr=arr.map(function(item){
return item*2;
})
console.log(newArr);//2,4,6,8,10
在vue中,就是采用的声明式渲染方式,只要明确挂载元素和data值就好,复杂的赋值过程vm帮你实现了。
<div id='demo'>
<span>{{message}}</span>
</div>
<script src='vue.js'></script>
<script>
// 数据
let obj={
message:'hello vue',
id:'123'
}
// 声明式渲染
var vm= new Vue({
el:'#demo',
data:obj
})
console.log(vm.$data)
</script>
指令
是一种特殊的自定义行间属性
指令的职责就是当其表达式的值改变时,相应的某些行为应用到DOM上
在vue中,指令以V-开头
Vue中的内置指令
- v-bind 动态的绑定数据,简写为 :
- v-on 绑定事件监听器,简写为@
- v-text 更新数据,会覆盖已有结构
- v-html 可以解析数据中的HTML
- v-show 根据值得真假,切换元素的display属性
- v-if 根据值得真假,切换元素会被销毁、重建
- v-else 条件都不符合渲染
- v-else-if多条件进行判断,为真则渲染
- v-for基于原数据多次渲染元素或模板块
- v-model在表单控件元素上创建双向数据绑定
- v-pre跳过元素和子元素的编译过程
- v-once只渲染一次,随后数据更新不重新渲染
模板
HTML模板
基于DOM的模板,模板都是有效的可解析的HTML
<div id='demo'>
<div v-html="html" :custom='abc'></div>
{{true?'yes':'no'}}
</div>
<script src='vue.js'></script>
<script>
// 数据
let obj={
html:'<div>hello vue.js</div>',
abc:'123'
}
// 声明式渲染
var vm= new Vue({
el:'#demo',
data:obj
})
插值
- 文本:使用‘mustache’语法{{value}}
- 作用:替换实例上的属性值,当值改变时,插值内容处会自动更新
- 原生的HTML:双大括号输出的是文本,不会解析HTML
- 属性:可以使用v-bind 绑定,可以响应变化。
- 使用javascript表达式:写简单地表达式
字符串模板
template模板
<div id='demo'>
<div v-html="html" :custom='abc'></div>
</div>
<script src='vue.js'></script>
<script>
// 数据
let obj={
html:'<div>hello vue.js</div>',
abc:'123'
}
var str='<div>hello,{{abc}}</div>'
// 声明式渲染
var vm= new Vue({
el:'#demo',
data:obj,
template:str
})
页面显示 hello,123
- template选项对象属性
- 模板将会替换挂载的元素,挂载元素的内容将被忽略
- 根节点只能有一个
- 将HTML结构写在一对script标签中,设置type="x-template"
模板render函数
- render选项对象的属性
- createElement(标签名,[数据对象],子元素);其中子元素为文本或按钮。
vue刨坑(二)的更多相关文章
- vue踩坑(二):跨域以及携带cookie
最近后台需求要在请求的时候传cooki给后台,正常情况下拿到cookie后存在cookie里,同域名下是会自己带到请求头里的,但是因为要在本地调试,那么问题就来了,localhost:8080下面的c ...
- Vue刨坑
vue常见问题 1.在自定义组件里,你可以像任何普通元素一样用v-for.eg1: <my-component v-for="item in items"></m ...
- Vue 爬坑之路(十二)—— vue-cli 3.x 搭建项目
Vue Cli 3 官方文档:https://cli.vuejs.org/zh/guide/ 一.安装 @vue/cli 更新到 3.x 之后,vue-cli 的包名从 vue-cli 改成了 @vu ...
- Vue入坑教程(二)——项目结构详情介绍
之前已经介绍了关于Vue的脚手架vue-cli的安装,以及一些文件目录介绍.具体可以查看<vue 入坑教程(一)--搭建vue-cli脚手架> 下面简单说一下具体的文件介绍 (一) pac ...
- Vue 爬坑之路(二)—— 组件之间的数据传递
Vue 的组件作用域都是孤立的,不允许在子组件的模板内直接引用父组件的数据.必须使用特定的方法才能实现组件之间的数据传递. 首先用 vue-cli 创建一个项目,其中 App.vue 是父组件,com ...
- (转)Vue 爬坑之路(二)—— 组件之间的数据传递
Vue 的组件作用域都是孤立的,不允许在子组件的模板内直接引用父组件的数据.必须使用特定的方法才能实现组件之间的数据传递. 首先用 vue-cli 创建一个项目,其中 App.vue 是父组件,com ...
- Vue 爬坑之路(六)—— 使用 Vuex + axios 发送请求
Vue 原本有一个官方推荐的 ajax 插件 vue-resource,但是自从 Vue 更新到 2.0 之后,官方就不再更新 vue-resource 目前主流的 Vue 项目,都选择 axios ...
- Vue 爬坑之路(九)—— 用正确的姿势封装组件
迄今为止做的最大的 Vue 项目终于提交测试,天天加班的日子终于告一段落... 在开发过程中,结合 Vue 组件化的特性,开发通用组件是很基础且重要的工作 通用组件必须具备高性能.低耦合的特性 为了满 ...
- Vue 爬坑之路(一)—— 使用 vue-cli 搭建项目
vue-cli 是一个官方发布 vue.js 项目脚手架,使用 vue-cli 可以快速创建 vue 项目,GitHub地址是:https://github.com/vuejs/vue-cli vue ...
随机推荐
- 在React Native中集成热更新
最近,在项目DYTT集成了热更新,简单来说,就是不用重新下载安装包即可达到更新应用的目的,也不算教程吧,这里记录一下. 1.热更新方案 目前网上大概有两个比较广泛的方式,分别是 react-nativ ...
- PHP成随机字符串
生成随机字符串 /** * 随机字符串 * @param int $len * @return string */ function randomStr($len = 32) { $chars = & ...
- JavaScript编码加密
网上看到的加密方法: JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,deco ...
- python__标准库 : 正则表达式(re)
re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none. re.search 扫描整个字符串并返回第一个成功的匹配. 替换: re.sub(p ...
- 关于对GitHub的使用
什么是GitHub? GitHub是版本控制和协作的代码托管平台.它可以让你在其他人在任何地方一起工作. 本文主要向您介绍GitHub essentials,如存储库,分支,提交和合并请求.将您创建自 ...
- 《Python语言及其应用》学习笔记
第二章 ========== 对象的类型决定了可以对它进行的操作.对象的类型还决定了它装着的数据是允许被修改的变量(可变的),还是不可被修改的常量(不可变的). Python是强类型的,你永远无法修改 ...
- 第四模块:网络编程进阶&数据库开发 口述
进程即正在执行的一个过程.进程是对正在运行程序的一个抽象. 子进程死了之后 ,父进程关闭的时候要清理掉子进程的僵尸进程(收尸),孤儿进程是指父进程先死掉了的,交给init管理. join() 等待子进 ...
- win7重装后恢复grub和ubuntu14
没有光盘和优盘启动盘,可以在win7下安装easybcd,添加一个启动选项为linux grub2,启动后进入ubutnu,执行如下: sudo -i //取得root权限 fdisk -l ...
- markdown备忘
文章主要(99%)参考自:markdown基本语法 这是二级标题 这是加粗的文字 这是倾斜的文字` 这是引用的内容 这是引用的内容 以下是分割线: 超链接 列表内容1 列表内容2 列表内容3 1.列表 ...
- (原)Unreal Shader模块(一): 着色创建
一.着色加载 这里说的Shader是编译后的文件或内存 源码说明 --------------------------------------------------------------- ...