VUE 1.0
现代开发模式:vue/react。 20%的时间花在了表现层
传统开发模式:jquery。 80%的时间花在了表现层
MVC——数据、表现、行为分离
视图层(表现层)<----->数据层
MVC、MVP、MVVM
vue的核心是数据,vue是典型的MVVM结构
前台渲染 vs 后台渲染
前台渲染好处:降低服务器负担、带宽压力小、用户体验好、
后台渲染好处:SEO更好、兼容性更好、安全性更高
指令(directive)——补充了html的属性
v-bind(简写为:):向html属性里面输出东西,可以用于任何属性,有两个属性有另外的写法:class、style。这两个属性可以用数组以及json。
v-model:数据双向绑定。只要用于输入组件(input,...),数据(data)和input之间双向绑定。
通过v-model进来的数据都是字符串。
v-text和v-html:一个是转义输出一个是非转义输出
v-text比较少用,直接输出html代码;v-html是innerHTML;
v-on:eg:v-on:click="fn()",()可以不加东西
v-on的简称是@,@click="fn()"。
事件修饰符:
@click.stop = 'fn()'——阻止冒泡
@click.once = 'fn()'——单次事件
@click.prevent = 'fn()'——阻止默认事件
@click.native——原生事件(组件)
@keydown.enter——筛选按键 .keycode|name|
@keydown.ctrl.enter——组合按键
@self
@capture
v-show 只是显示隐藏,控制元素的display
v-if 会删除这个元素
v-for
1.循环数组 v-for="item,index in array"
2.循环json v-for="val,key in json"
3.循环字符串 v-for="char,index in str"
4.循环数字 v-for="i in num"
跟for密切联系的:key
虚拟dom——json
:key属性(跟虚拟dom有巨大的关系)
1.key属性不能重复(唯一)
2.key属性不能改变
v-pre——预编译
提高性能
放置意外的解析
v-cloak
渲染未完成时不显示vue代码,*[v-cloak]{display:none}
1.vm结构
new Vue({
el,data,methods,
computed,props,watch,template,router,.......
})
2.概念
数据同步
双向绑定
虚拟DOM
3.指令
双向绑定:
<script>
let el = document.getElementById('div1');
let template = el.innerHTML;
let _data = {
name:'blue',
age:,
}
let data = new Proxy(_data,{
set(obj,name,value){
obj[name]=value;
console.log(`有人试图设置${name}=>${value}`);
render();
},
get(){
},
});
render();
function render(){
//渲染
el.innerHTML = template.replace(/\{\{\w+\}}/g,str=>{
str = str.substring(,str.length-);
return _data[str];
})
//找所有的v-model
Array.from(el.getElementBysTagName('input'))
.filter(ele=>ele.getAttribute('v-model'))
.forEach(input=>{
let name = input.getAttribute('v-model');
input.value = _data[name];
input.oninput = function(){
data[name] = this.value;
};
});
}
</script>
虚拟DOM:
合并请求,快速查询,局部刷新
computed——计算属性
1.缓存——性能
2.方便——可读可写,属性的形式
<div id="div1">{{a}}+{{b}}={{sum}}</div>
let vm = new Vue({
el:'#div1',
data:{ a:, b, },
computed:{
sum(){ return this.a+this.b; }
}
})
<div id="div1">
姓:<input type="text" v-model="familyName"><br>
名:<input type="text" v-model="givenName"><br>
<input type="text" v-model="name">
</div>
let vm = new Vue({
el:'#div1',
data:{ familyName:'张',givenName:‘三’ },
computed:{
name:{
get(){ return this.familyName+this.givenName; },
set(value){
this.familyName=value[0];
this.familyName=value.substring(1);
}
}
}
})
watch——监听(适合做搜索栏下拉提示选项)
vue-router
1.路由容器 <router-view></router-view>
2.路由表 let router = new VuewRouter( {path,component}, {path,component}, {path,component},.....)
3.添加到vm对象 new Vue({ el,data,...,router:router })
router-view 容器
router-link a标签
数据交互
组件
VUE 1.0的更多相关文章
- 使用 Vue 2.0 实现服务端渲染的 HackerNews
Vue 2.0 支持服务端渲染 (SSR),并且是流式的,可以做组件级的缓存,这使得极速渲染成为可能.同时, 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration.v ...
- 新手入门指导:Vue 2.0 的建议学习顺序
起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...
- vue 2.0 无法编译ES6语法
# vue2.0 webpack 无法编译 ES6 语法 之前在使用 vue 1.x 时用 vue-loader@8.0.0 版本可以正常打包vue的代码,包括ES6语法也能正常转为ES5语法,但是当 ...
- Vue 2.0初学后个人总结及分享
摘要:最近在上海找工作,发现Vue前景还不错,于是就打算先学习一下(之前了解过,但是一直没提到日程上)这篇随笔当是为了自己学习之后,做一个小的阶段性总结.希望本文的内容对于刚开始接触vue的朋友们有点 ...
- 《vue.js2.0从入门到放弃》学习之路
原文地址: Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374 Vue.js2.0从入 ...
- Vue 2.0基础语法:系统指令
本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. Vue初体验 新建一个空的项目,引入vue.js文件.写如下代码: &l ...
- vue 2.0 路由切换以及组件缓存源代码重点难点分析
摘要 关于vue 2.0源代码分析,已经有不少文档分析功能代码段比如watcher,history,vnode等,但没有一个是分析重点难点的,没有一个是分析大命题的,比如执行router.push之后 ...
- vue-calendar 基于 vue 2.0 开发的轻量,高性能日历组件
vue-calendar-component 基于 vue 2.0 开发的轻量,高性能日历组件 占用内存小,性能好,样式好看,可扩展性强 原生 js 开发,没引入第三方库 Why Github 上很多 ...
- vue cli3.0 结合echarts3.0和地图的使用方法
echarts 提供了直观,交互丰富,可高度个性化定制的数据可视化图表.而vue更合适操纵数据. 最近一直忙着搬家,就没有更新博客,今天抽出空来写一篇关于vue和echarts的博客.下面是结合地图的 ...
- Vue 1.0 和 2.0 执行顺序
// Vue 生命周期 // Vue 1.0 // 执行步骤:选项/生命周期钩子 // 1 init // 2 created // 3 beforeCompile // 4 compiled // ...
随机推荐
- kubernetes Configmap secret的使用
kubernetes configmap 核心作用是让配置信息和镜像解耦,pod可以使用configmap的数据生成配置文件.如果后端的pod配置文件要改变时,只需要更改下configmap里面的数据 ...
- windows下mysql 主库从库同步
今天先讲讲数据库的主从同步,两个好处: 一是读写分离可以用上.比如 写操作就写到主数据库,读就再从库读取 二是纯粹给数据库备份,以防硬盘彻底崩了 主从数据库操作准备: 两台电脑,都安装好mysql 5 ...
- 阿里云Ubuntu安装LNMP环境之Nginx
在QQ群很多朋友问阿里云服务器怎么安装LNMP环境,怎么把项目放到服务器上面去,在这里,我就从头开始教大家怎么在阿里云服务器安装LNMP环境. 在这之前,我们先要知道什么是LNMP. L: 表示的是L ...
- 栈的数组和链表实现(Java实现)
我以前用JavaScript写过栈和队列,这里初学Java,于是想来实现栈,基于数组和链表. 下面上代码: import java.io.*; //用接口来存放需要的所有操作 interface st ...
- Failed to execute goal maven-gpg-plugin 1.5 Sign
问题描述: 解决办法:跳过maven-gpg-plugin <build> <pluginManagement> <plugins> <plugin> ...
- IDEA + tomcat 远程调试(JPDA)
一.修改 tomcat 配置,启动远程调试 Linux(bin\catalina.sh) # 将 localhost 改为 0.0.0.0 if [ -z "$JPDA_ADDRESS&qu ...
- redis---set类型常用命令
添加元素:sadd key value1 value2 查看指定key包含的元素:smembers key 判断指定元素是否存在于key的value中(0表示不存在,1表示存在):sismember ...
- 对String的内存解析
@Test public void stringTest(){ /* * str1和str2地址指向字符串常量池 * 解析: str1 在字符串常量池中创建出java 地址例如为:0x456 * st ...
- LNMP分离
1.Nginx 找php 在nginx 配置文件的server里 添加 location ~.*\.(php|php5)?$ { root /var/www/html/wwwcom; fastc ...
- jQuery常用操作部分总结
注意:$(“.xxx”) 类,一定要在前面加上点callback为完成后执行的函数名称隐藏显示:hide() show()淡入淡出:fadeIn() fadeOut() fadetoggl ...