vuejs框架入门

mvvm图例

这张图足以说明MVVM的核心功能,在这三者里面,ViewModel无疑起着重要的桥梁作用。

  • 一方面,通过ViewModel将Model的数据绑定到View的Dom元素上面,当Model里面的数据发生变化的时候,通过ViewModel里面数据绑定的机制,触发View里面Dom元素的变化;
  • 另一方面,又通过ViewModel来监听View里面的Dom元素的数据变化,当页面上面的Dom元素发生变化的时候,ViewModel通过Dom树的监听机制,触发对应的Model的数据变化。

一、最简单的vuejs应用

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
</head>
<body>
<div id="app">
<h1>姓名:{{Name}}</h1>
<h1>年龄:{{Age}}</h1>
<h1>学校:{{School}}</h1>
</div>
<script type="text/javascript" src="js/vue.min.js"></script>
<script type="text/javascript">
//Mode
var data={
Name:"yjw",
Age:100,
School:"启二"
}
//ViewModel
var vm = new Vue({
el:"#app",
data:data
})
</script>
</body>
</html>

其中 el:表示绑定的Dom元素,此例子中表示的是父级的Dom元素。

  data:需要绑定的数据Model。

二、双向数据绑定

通过v-model 实现双向数据绑定 如 编辑姓名:<input type="text" v-model="Name" />

三、简单的基于vuejs增删改查

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>tabel</title>
<link rel="stylesheet" href="css/bootstrap.min.css" type="text/css">
<style>
th,td{text-align: center;}
ul{margin:0; padding: 0;}
.box{width: 800px; height: 600px; float: left; margin-left: 100px;}
.box .breadcrumb{margin-bottom:0;}
</style>
</head>
<body>
<div id="app" class="box">
<ul class="breadcrumb">
<li><a href="#">用户管理</a> <span class="divider">/</span></li>
</ul>
<table class="table table-bordered table-striped text-center">
<thead>
<tr>
<th>name</th>
<th>age</th>
<th>school</th>
<th>back</th>
<th>option</th>
</tr>
</thead>
<tbody>
<template v-for="row in rows">
<tr>
<td>{{row.Name}}</td>
<td>{{row.Age}}</td>
<td>{{row.School}}</td>
<td>{{row.Back}}</td>
<td><a href="#" v-on:click="Edit(row)">编辑</a> &nbsp;&nbsp; <a href="#" v-on:click="Del(row.Id)">删除</a></td>
</tr>
</template>
<tr>
<td><input class="form-control" type="text" v-model="rowtemplate.Name"></td>
<td><input class="form-control" type="text" v-model="rowtemplate.Age"></td>
<td><input class="form-control" type="text" v-model="rowtemplate.School"></td>
<td><input class="form-control" type="text" v-model="rowtemplate.Back"></td>
<td><button class="btn btn-primary" v-on:click="Save">保存</button></td>
</tr>
</tbody>
</table>
</div> <script src="js/vue.min.js"></script>
<script>
var data = {
rows:[
{Id:1,Name:'asdfg',Age:20,School:'q2',Back:'asd'},
{Id:2,Name:'asdfg',Age:30,School:'q2',Back:'asd'},
{Id:3,Name:'asdfg',Age:40,School:'q2',Back:'asd'},
{Id:4,Name:'asdfg',Age:50,School:'q2',Back:'asd'},
{Id:5,Name:'asdfg',Age:60,School:'q2',Back:'asd'}
],
rowtemplate:{Id:0,Name:'',Age:'',School:'',Back:''}
}
var v = new Vue({
el:"#app",
data:data,
methods:{
Edit:function(row){
this.rowtemplate = row;
},
Save:function(){
if(this.rowtemplate.Id === 0){
this.rowtemplate.Id = this.rows.length+1;
this.rows.push(this.rowtemplate);
}
},
Del:function(id){
for(var i=0; i<this.rows.length;i++){
if(this.rows[i].Id == id){
this.rows.splice(i,1);
}
}
}
}
})
</script>
</body>
</html>

---------------------------------------

应用vue-cli构建应用

在使用vue-cli之前我们需要安装node.js,利用其提供的npm命令来安装vue-cli。安装node.js只需去其官网下载软件并安装即可,地址为:https://nodejs.org/en/
安装完成之后我们打开电脑的cmd命令行工具依次输入上图中的命令:

(1)npm install -g vue-cli:全局安装vue-cli

(2)vue init webpack my-project: 利用vue-cli在目录地址生成一个基于webpack的名为’my-project‘的Vue项目文件及目录

(3)cd my-project:打开刚刚创建的文件夹

(4)npm intall:安装项目所依赖的包文件

(5)npm run dev:利用本地node服务器在浏览器中打开并浏览项目页面

这样我们的一个基于webpack的vue项目目录就构建好了。

 

vuejs入门备忘&&用vuecli构建应用的更多相关文章

  1. vux 入门备忘大佬多指点

    一.安装node.js https://nodejs.org/en/ 这样就可以使用npm喽 二.安装vux 安装vux npm install vux --save 安装vux-loader npm ...

  2. vux Tabbar组件入门备忘大佬多指点

    一.Tabbar引入及使用 1.新创建vue文件 2.在vue文件中添加插件 <template> <div> <tabbar style="position: ...

  3. spark入门备忘---1

    import org.apache.spark.{SparkContext, SparkConf} import scala.math.random /** * 利用spark进行圆周率的计算 */ ...

  4. Webstorm常用快捷键备忘(Webstorm入门指南)

    WebStorm 是jetbrains公司旗下一款JavaScript 开发工具.被广大中国JS开发者誉为“Web前端开发神器”.“最强大的HTML5编辑器”.“最智能的JavaSscript IDE ...

  5. Haxe UI框架StablexUI的使用备忘与心得(序)

    最近在手上的项目开发中,从原来的使用Sprite全手写UI,开始逐步使用StablexUI,感觉还是相当不错的,强大.高效.轻量.灵活,非常适应我当前的实际需求. 不过作为小种语言的一个小众第三方开源 ...

  6. 探索 vuex 2.0 以及使用 vuejs 2.0 + vuex 2.0 构建记事本应用

    前言 首先说明这并不是一个教程贴,而记事本应用是网上早有的案例,对于学习 vuex 非常有帮助.我的目的是探索 vuex 2.0 ,然后使用 vue 2.0 + vuex 2.0 重写这个应用,其中最 ...

  7. 中文代码示例之Vuejs入门教程(一)

    原址: https://zhuanlan.zhihu.com/p/30917346 为了检验中文命名在主流框架中的支持程度, 在vuejs官方入门教程第一部分的示例代码中尽量使用了中文命名. 所有演示 ...

  8. AngularJS之备忘与诀窍

    译自:<angularjs> 备忘与诀窍 目前为止,之前的章节已经覆盖了Angular所有功能结构中的大多数,包括指令,服务,控制器,资源以及其它内容.但是我们知道有时候仅仅阅读是不够的. ...

  9. 利用 vue-cli 构建一个 Vue 项目

    一.项目初始构建 现在如果要构建一个 Vue 的项目,最方便的方式,莫过于使用官方的 vue-cli . 首先,咱们先来全局安装 vue-cli ,打开命令行工具,输入以下命令: $ npm inst ...

随机推荐

  1. 在Linux下安装redis

    http://www.cnblogs.com/xiaohongxin/p/6854095.html 追加: 通过配置文件启动最好先./redis.cli shutdown ,再到当前目录在./redi ...

  2. React动态import()

    React动态import() react-router@v4代码分离,推荐的import().这里分享webpack配置和使用方法. 首先安装两个必须的包 cnpm i react-loadable ...

  3. vtigercrm安装

    vtigercrm是一个用户关系管理系统. 本以为安装只用半个小时就可以完成,结果花了两天时间.. 后来因为不想其他的因素影响,重新装了个纯净的系统.(系统为ubuntu16,安装过程略) 在系统基础 ...

  4. GoF23种设计模式之行为型模式之观察者模式

    一.概述        定义对象之间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新.二.适用性1.当一个抽象模型有两个方面,其中一个方面依赖于另一方面的时 ...

  5. F查询与Q查询

    F查询 如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的比较.F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值. # 查询评论 ...

  6. The 2018 ACM-ICPC Chinese Collegiate Programming Contest Maximum Element In A Stack

    //利用二维数组模拟 #include <iostream> #include <cstdio> #include <cstring> #include <s ...

  7. jenkins匿名用户登录 - 安全设置

    最近自己安装配置jenkins,但是跑任务时,发现是匿名账户登录,且提示: 后来发现搭建好jenkins之后,默认就是匿名用户登录的,可以在安装设置菜单里进行账户管理. 1.登录Jenkins服务器, ...

  8. bash脚本编写基础

    bash脚本编程     命令的堆砌     脚本程序:解释器解析执行     shell:交互式接口,编程环境         shell:能够提供一些内部命令,并且能通过PATH环境变量找到外部命 ...

  9. poj 3281 Dining(网络流+拆点)

    Dining Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 20052   Accepted: 8915 Descripti ...

  10. Linux的档案权限与目录配置练习题

    1.请说明/bin与/usr/bin目录所防止的执行文件有何不同之处:/bin主要放置在开机时,以及进入单人维护模式后还能够被使用的指令,至于/usr/bin则是大部分软件提供的指令放置处 2.请说明 ...