现代开发模式: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的更多相关文章

  1. 使用 Vue 2.0 实现服务端渲染的 HackerNews

    Vue 2.0 支持服务端渲染 (SSR),并且是流式的,可以做组件级的缓存,这使得极速渲染成为可能.同时, 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration.v ...

  2. 新手入门指导:Vue 2.0 的建议学习顺序

    起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...

  3. vue 2.0 无法编译ES6语法

    # vue2.0 webpack 无法编译 ES6 语法 之前在使用 vue 1.x 时用 vue-loader@8.0.0 版本可以正常打包vue的代码,包括ES6语法也能正常转为ES5语法,但是当 ...

  4. Vue 2.0初学后个人总结及分享

    摘要:最近在上海找工作,发现Vue前景还不错,于是就打算先学习一下(之前了解过,但是一直没提到日程上)这篇随笔当是为了自己学习之后,做一个小的阶段性总结.希望本文的内容对于刚开始接触vue的朋友们有点 ...

  5. 《vue.js2.0从入门到放弃》学习之路

    原文地址: Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374 Vue.js2.0从入 ...

  6. Vue 2.0基础语法:系统指令

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. Vue初体验 新建一个空的项目,引入vue.js文件.写如下代码: &l ...

  7. vue 2.0 路由切换以及组件缓存源代码重点难点分析

    摘要 关于vue 2.0源代码分析,已经有不少文档分析功能代码段比如watcher,history,vnode等,但没有一个是分析重点难点的,没有一个是分析大命题的,比如执行router.push之后 ...

  8. vue-calendar 基于 vue 2.0 开发的轻量,高性能日历组件

    vue-calendar-component 基于 vue 2.0 开发的轻量,高性能日历组件 占用内存小,性能好,样式好看,可扩展性强 原生 js 开发,没引入第三方库 Why Github 上很多 ...

  9. vue cli3.0 结合echarts3.0和地图的使用方法

    echarts 提供了直观,交互丰富,可高度个性化定制的数据可视化图表.而vue更合适操纵数据. 最近一直忙着搬家,就没有更新博客,今天抽出空来写一篇关于vue和echarts的博客.下面是结合地图的 ...

  10. Vue 1.0 和 2.0 执行顺序

    // Vue 生命周期 // Vue 1.0 // 执行步骤:选项/生命周期钩子 // 1 init // 2 created // 3 beforeCompile // 4 compiled // ...

随机推荐

  1. MFC 列表控件List Control

    一般用带有表头的报表模式,所以属性:View设为Report // OnInitDialog()中 CString str[] = {TEXT("姓名"),TEXT("性 ...

  2. slice(start, [end]) 选取一个匹配的子集 与原来的slice方法类似

    slice(start, [end]) 概述 选取一个匹配的子集 与原来的slice方法类似 参数 startIntegerV1.1.4 开始选取子集的位置.第一个元素是0.如果是负数,则可以从集合的 ...

  3. 011_linuxC++之_继承的引入

    (一)面向对象程序设计中最重要的一个概念是继承.继承允许我们依据另一个类来定义一个类,这使得创建和维护一个应用程序变得更容易.这样做,也达到了重用代码功能和提高执行时间的效果. (二)引入继承程序 # ...

  4. compile cmdow

    1. http://www.commandline.co.uk/ https://github.com/ritchielawrence/cmdow/tarball/master 2. g++ -O2 ...

  5. 【原创】洛谷 LUOGU P3371 【模板】单源最短路径

    P3371 [模板]单源最短路径 题目描述 如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 输入输出格式 输入格式: 第一行包含三个整数N.M.S,分别表示点的个数.有向边的个数.出 ...

  6. 使用Spring基于应用层实现读写分离(一)基础版

    背景 我们一般应用对数据库而言都是“读多写少”,也就说对数据库读取数据的压力比较大,有一个思路就是说采用数据库集群的方案, 其中一个是主库,负责写入数据,我们称之为:写库: 其它都是从库,负责读取数据 ...

  7. 【零基础】斯坦福四足机器人DIY指引

    可以后空翻的机器狗 近日斯坦福开源了一个四足机器人项目“Stanford Doggo”,“只需”3000美金就可以DIY一个能跳一米高兼后空翻的电子小狗,一段时间研究后我们写了这篇简单的指引帮助大家快 ...

  8. 操作系统 | 结合 CPU 理解一行 Java 代码是怎么执行的

    根据冯·诺依曼思想,计算机采用二进制作为数制基础,必须包含:运算器.控制器.存储设备,以及输入输出设备,如下图所示. 我们先来分析 CPU 的工作原理,现代 CPU 芯片中大都集成了,控制单元,运算单 ...

  9. jeecg随笔

    1.根据数据字典code查找该字典下的元素: SELECT typecode,typename from t_s_type where typegroupid=(select id from t_s_ ...

  10. Java相关框架概念以及思想

    1.什么是IoC Ioc—Inversion of Control,即“控制反转”,是一种思想, 一个重要的面向对象编程的法则,它能指导我们如何设计出松耦合.更优良的程序. 高内聚低耦合的设计能够让构 ...