Installation

可以使用的方式:

  1. script标签方式加载vue.js
  2. cdn https://unpkg.com/vue@2.0.5/dist/vue.js
  3. npm

Introduction

  1. 通过指定的语法渲染js变量
  2. DOM元素与变量绑定,同步更新,无需手动操纵DOM
  3. 通过vue标签属性,完成绑定data,绑定事件,条件语句以及循环等特性
  4. 创建自定义可复用的组件,可直接在html标签中使用

The Vue Instance

  1. Vue构造方法创建实例,并且可以扩展构造方法创建可重用的组件(继承?)
  2. 每一个Vue实例都代理了data参数中所有的属性,并且如果在Vue对象实例化之前你的自定义变量绑定到了data中,那么他们的值是时刻同步的
  3. 每个Vue对象在实例化的过程中,经历了一系列的过程,就是有它的生命周期

Template Syntax

  1. Vue使用基于HTML的语法,允许你将渲染到DOM中元素与Vue实例中的data数据绑定
  2. Vue把模板数据编译到虚拟DOM的渲染方法中,根据app不同的状态,实现最少量的组件的重新渲染
  3. {{}}法上可以渲染文本、可以支持javascript表达式,可以通过管道实现过滤

Computed Properties and Watchers

  1. {{}}语法中可以使用js表达式,但是并不推荐,不易于维护,不利于调试,引入 computed属性,compulted属性依赖于现有的属性,只要依赖值没变,其值不变,页面中多处使用可以直接返回计算好的值,与之对应的用方法实现,每次都要执行一遍
  2. 对于数据和页面的rective,compluted可以满足大多数情形,当你需要完成异步并且有大量的数据计算响应等操作,可以使用watch选项
  3. 总结:compluutedwatch的目的都是监听Vue实例数据的变化,并作出响应

Class and Style Bindings

  1. 使用Vue定义的属性v-bind:class可以进行样式类的绑定,支持丰富的格式,可以使用对象的方式在vuedata option中定义,可以使用数组传递多个类名,可以依赖于现有的data使用compluted属性,可以跟现有的html标签类混用等等
  2. v-bind:style可直接绑定书写行内样式,支持对象方式、数组方式

Conditional Rendering

  1. 条件标签v-if ,v-show,可以做条件判断来进行html元素的显示
  2. 不同点在于v-if根据值的变化每次重新渲染,v-show等价于display:show|none也就是元素是在页面中渲染好的

Event Handling

  1. v-on标签绑定各种事件,可以做v-on:click="counter += 1"这种简单的处理,也可以调用Vue中方法(方法可将原生的DOM event通过$event传递)
  2. 经常用到的阻止事件冒泡或阻止事件的默认行为在Vue中可以与v-on搭配使用点语法.stop .prevent .capture .self来实现,不需要再去关心具体的DOM事件细节
  3. 针对键盘的key值监听,Vue提供也提供了简单的绑定语法v-on:keyup.键值,也可使用vue提供的定义好的常用键值的别名

Form Input Bindings

  1. v-model可以处理基本的用户输入(input)、复选框、单选框等的值赋值给v-model指定的变量
  2. 仅仅使用v-model只可以获取用户输入的字符串或者true false(单、富选框),可以使用v-bind将input的value与vue的属性绑定,这样可以动态的修改

Components

  1. 组件用来扩展现有的html标签并进行封装重用
  2. 使用自定义components需要在实例化Vue对象之前确保组件已经注册
  3. 除注册为全局组件之外,可以注册为某一个vue实例的本地组件
  4. 在页面中直接使用自定义组件时,浏览器会无法解析,需要使用is=组件名
  5. 组件中的data option必须为一个function,否则console 报 warnning
  6. 组件复用不可避免的需要不同组件嵌套使用,涉及到数据的向下传递,Vue通过props option传递【注:props在js中的驼峰命名在html中需要改为连字符】
  7. 对于组件需要接收的参数,Vue提供了参数验证
  8. 子组件与父组件的通信是通过customer events即自定义事件
  9. v-on:事件名来监听子组件可能触发的事件
  10. v-on:click.native=""同样可以监听原生的JavaScript事件
  11. 非父子关系的组件也可以通过hook的方式完成通讯

Vue.js 指南-基础的更多相关文章

  1. Vue.js应用基础

    声明 这篇博文是我的Vue学习记录,其中参杂了不少我个人的理解,由于我并没有继续学习Vue的源码,所以不能保证这些理解都是正确的.如果这篇博文有幸被你读到,请带着批判的心情去审视它. 如果你发现了其中 ...

  2. Vue.js的基础学习

    Vue.js的基础网上很多,这里不记录 开始正式页面的开发 1.页面加载时请求数据 methods: { post() { //发送post请求 this.$http.post('../../ashx ...

  3. Vue.js教程--基础(实例 模版语法template computed, watch v-if, v-show v-for, 一个组件的v-for.)

    官网:https://cn.vuejs.org/v2/guide/index.html Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统. 视频教程:https: ...

  4. Vue.JS学习基础

      = 导航   顶部 vue.js介绍 vue.js实例 模板语法 计算属性 样式绑定 条件渲染 列表渲染 事件处理器 表单控件绑定 组件   顶部 vue.js介绍 vue.js实例 模板语法 计 ...

  5. Vue.js教程--基础2(事件处理 表单输入绑定

    事件处理 表单输入绑定 事件处理 监听v-on 监听 DOM 事件,并在触发时运行一些 JavaScript 代码. 可以在v-on:click=''加内联语句. 有时也需要在内联语句处理器中访问原始 ...

  6. vue.js的基础与语法

    Vue的实例 创建第一个实例: {{}} 被称之为插值表达式.可以用来进行文本插值. <!DOCTYPE html> <html lang="en"> &l ...

  7. Vue.js 基础指令实例讲解(各种数据绑定、表单渲染大总结)——新手入门、高手进阶

    Vue.js 是一套构建用户界面的渐进式框架.他自身不是一个全能框架--只聚焦于视图层.因此它非常容易学习,非常容易与其它库或已有项目整合.在与相关工具和支持库一起使用时,Vue.js 也能完美地驱动 ...

  8. Vue.js 基础快速入门

    Vue.js是一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的.Vue.js提供了简洁.易于理解的API,使得我们能够快速地上手并使用Vue.js 如果之前已经习惯了用jQue ...

  9. Vue.js——60分钟快速入门

    Vue.js介绍 Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的.相比于Angular.js,Vue.js提供了更加简洁.更易于理解的API,使得我们 ...

随机推荐

  1. 话说Fetch这个API

    前言: 最近在研究React这个框架,成功的成为了一名新的入坑着.用过React的都知道React的强大主要是在于它的生态的 强大,React说的再大不过也就是一个UI框架罢了.不过我们学习react ...

  2. MVC源码解析 - 进入CLR

    这一篇是转载自汤姆大叔的一篇随笔. IIS 5 的 ASP.net 请求处理过程 IIS5核心特征是:IIS是允许在一个叫InetInfo.exe的进程上的,所以无论是aspx页面还是html页面都是 ...

  3. Python第一天——入门Python(3)列表

    列表,也是一种序列类型. 如何定义列表? 用" [ ] "(中括号进行定义) 列表的索引操作 例如 # hobby_list=['basketball','football','p ...

  4. JSON 与 对象 、集合 之间的转换

    JSON字符串和java对象的互转[json-lib]   在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JSON等,JSON作为一个轻量级的数据格式比xml效率要高,XML需要很 ...

  5. Spark集群搭建步骤

    问题: 参考:Spark快速入门指南 – Spark安装与基础使用

  6. xtrabackup在线备份及还原

    xtrabackup下载https://www.percona.com/downloads/XtraBackup/LATEST/xtrabackup文档https://www.percona.com/ ...

  7. 让innerHTML获取的内容包含input和select(option)的最新值

    function refreshData(){ var allInputObject=document.body.getElementsByTagName("input"); fo ...

  8. java输出菱形

    package test; public class Test { public static void main(String[] args) { for(int i=1;i<=4;i++){ ...

  9. textfile 属性

    //设置textfile的Placeholder的颜色和字体大小 nameText.attributedPlaceholder = NSAttributedString.init(string: &q ...

  10. Servlet源码初探

    年底,公司的事情告一段落,就来捣鼓一下这个Servlet源码,为下一步的spingmvc源码初探做准备 1.Servlet接口 public interface Servlet { void init ...