写在前面的话!

每个新的框架入手都会进行一些列的扯犊子!这里不多说那么多!简简单单说一下vue吧!

Vue.js是目前三大框架(angular,vue,react)之一,是渐进式js框架,据说是摒弃了了其他的两者框架的缺点继承了优点!容易上手,效率高,压缩版源码仅20k!中文文档比较完善(或许这个就是我要学这个原因吧),vue在中国市场比重还是比较大!废话不说开始进行走进Vue.js的学习之旅吧!接下来进行一天入门Vue.js到放弃系列!

初始Vue.js

中文文档:

首先进行下载Vue.js最新版本

为了在学习环境中我们选择开发版的源代码有助于我们学习,会在控制台发生错误报告错误!

这里提供一个cdn在线vuejs的地址,最好保存本地,由于接下来我们要进行折腾vue的一天开始了!

  1. <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

准备工作完成了,我们还是书写一个伟大的入门级的Vue.js(hello world程序)

新建一个html文件(index.html为例)

  1. <div id="app">-->
  2. <p v-model="who">我们是谁? {{who}}</p>
  3. <p v-model="progress">我们在写什么程序? {{progress}}</p>
  4. <p v-model="lang">伟大的从入门到放弃系列 {{lang}} 开始了 </p>
  5. </div>

js代码(main.js)

  1. let app = new Vue({
  2. el: "#app",
  3. data: {
  4. who: "程序员",
  5. progress: "Hello World",
  6. lang: "Vue.js",
  7. }
  8. });

html的页面中双花括号中的变量的调取来自js文件中的data,el:表示vue的容器,这个是表示在id为app的元素下完成页面渲染,当然可以进行设置一个全局变量,通过控制台修改data的数据,页面中的显示都会发生变化!

也可以是下面的给input绑定一个v-model,通过输入输入的内容动态可以改变显示内容

  1. <p>
  2. <input type="text" v-model="name">
  3. 我的名字是 {{name}}
  4. </p>
  5. <p>
  6. <input type="text" v-model="age">
  7. 我今年 {{age}} 岁
  8. </p>

系统学习vue语法

vue系统指令:

vue-for

上面一个案例简单的看出了vue和之前的不一样,从此可以说dom操作从此就是形同陌路,下面看一下vue实现for循环

index.html页面

  1. <ul >
  2. <li v-for="good in goods"> 手机名称:{{good.name}},手机原价:&yen;{{good.price}},手机折扣价:&yen;{{(good.zhekou)?good.price*good.zhekou:good.price}} </li>
  3. </ul>

main.js代码

  1.  
  1. var app = new Vue({
  2. el: "#app",
  3. data: {
  4. goods:[
  5. {
  6.  
  7. id:5,
  8. name:"小米8",
  9. price:2999,
  10. zhekou:0.98
  11. },
  12. {
  13. id:23,
  14. name:"小米mix2S",
  15. price:3299,
  16. zhekou:0.9
  17. },
  18. {
  19. id:73,
  20. name:"iPhone X",
  21. price:7388
  22. },
  23. {
  24. id:52,
  25. name:"华为P20Pro",
  26. price:4998,
  27. zhekou:0.985
  28. }
  29. ]
  30. }

这里使用了for in的方式进行循环出data中的数据! v-if(good in goos),表名这个good就是来自data中的商品数组的item(子项),获取的时候只需要进行goos.对象名称就可以显示

v-bind

使用v-bind绑定超链接的href地址

inde.html

  1.  
  1. <a v-bind:href="url">{{title}}</a>

main.js中

  

  1. app = new Vue({
  2. el: "#app",
  3.  
  4. data:{
  5. title:"点我去百度",
  6. aaa:"btn btn-default",
  7. url:"http://baidu.com",
  8. isActive:true
  9.  
  10. }
  11. });

此时可以动态改变data的url点击超链接跳转不同的页面

我们还可以使用这个v-bind添加class值

index.html

  1. //不管什么时候都添加class
  2. <a href="" v-bind:class="{aaa}">000</a>
  3. //动态的选择添加class,状态激活后添加btn这个class
  4. <a href="#" :class="{ btn: isActive }">我有class属性</a>

在上述中你或许细心已经观察到了我使用了:class进行绑定,vue为了提供极大的便利,  这里是v-bind的替代写法用 :  效果一样!

v-on

index.html

  1. //点击事件
  2. <a href="#" v-on:click="isClick">点我</a>
  3. //键盘事件
  4. <input type="text" @keyup="onKeyup" @keyup.enter="onKeyenter">
  5. //绑定多个事件
  6. <button v-on="{mouseenter:onEnter,mouseleave:onOut}">移动区域</button>

main.js

  

  1. app = new Vue({
  2. el: "#app",
  3. methods:{
  4. isClick:function(){
  5. console.log("鼠标点击成功")
  6. },
  7. noClick:function(){
  8. console.log("这个按钮不能点大哥!")
  9. },
  10. onEnter:function(){
  11. console.log("鼠标移入")
  12. },
  13. onOut:function(){
  14. console.log("鼠标移出")
  15. },
  16. Onsubmit:function(e){
  17. e.preventDefault();
  18. console.log("submitted")
  19. },
  20. onKeyup:function(){
  21. console.log("你按下了键盘!!!")
  22. },
  23. onKeyenter:function(){
  24. console.log("你摁下的是enter键")
  25. }
  26.  
  27. }

对于不同的绑定的事件,执行的函数可以卸载vue的methods对象中,当然这个v-on和v-bind也是几个常用属性,也是拥有快捷替代方式的  可以使用@替代v-bind

v-model

在开始书写hello world程序你或许已经见过这个v-model这个指令,在这里我们详细说明一下他的使用范围已经修饰参数的区别

index.html

不同参数的区别
  1.  
  1. <div id="app">
  2. <p>时时更新数据</p>
  3. <input type="text" v-model="name">
  4. {{name}}
  5. <p>失去焦点(blur)时候改变dom数据</p>
  6. <input type="text" v-model.lazy="name">
  7. {{name}}
  8. <p>v-model.number返回的是数字number类型</p>
  9. <input type="text" v-model.number="uid">
  10. {{uid}}
  11. <p>v-model.trim去除输入的多余空格</p>
  12. <!--<input type="text" v-model="name">-->
  13. <input type="text" v-model.trim="name">
  14. <pre>{{name}}</pre>
  15. </div>

v-model.lazy懒惰变更数据,不想之前时时改变,这个是只要在input数去焦点(blur)的时候改变

v-model.number输入框中的数据以数字形式进行,主要用于计算的时候,如果手动输入在input的这是会当做String(字符串处理)

v.model-trim:在空格存在的input中会剔除掉空格

vue-model使用范围:

上面的主要使用了input的type="text"的应用这里看一下,type是checkbox和radio的类型

index.html

  1.  
  1. <p>性别:</p>
  2. <input type="radio" v-model="sex" value="boy">
  3. <br>
  4. <input type="radio" v-model="sex" value="gril">
  5. <br>
  6. {{sex}}
  7. <label for="">爱好:</label>
  8. <input type="checkbox" v-model="hobby" value="JAVA">JAVA
  9. <input type="checkbox" v-model="hobby" value="PHP">PHP
  10. <input type="checkbox" v-model="hobby" value="web前端">web前端
  11. <input type="checkbox" v-model="hobby" value="C++">C++
  12. <input type="checkbox" v-model="hobby" value="Node.js">Node.js
  13. {{hobby}}
  14. <br>

在radio中返现选择哪个会呈现哪个选项的value值,在多选框中会呈递所选的选项数组的value

多行文本和input的type="text"的实则一样,没什么变化

  1.  
  1. <textarea name="" cols="30" rows="10" v-model="article">
  2. </textarea>
  3. {{article}}

绑定artice到data,手动改变后,下面呈递的article也随之改变

select的使用

  1. <p>下拉选项表</p>
  2. 我的选择:
  3. <select v-model="add">
  4. <option value="1">北京</option>
  5. <option value="2">丽江</option>
  6. <option value="3">上海</option>
  7. <option value="4">金三桥</option>
  8. <option value="5">钓鱼岛</option>
  9. </select>
  10. 我想去的地方是:{{add}}
  11. <p>我喜欢吃:</p>
  12. <select name="" id="" v-model="food" multiple>
  13. <option value="1">胡辣汤</option>
  14. <option value="2">炸酱面</option>
  15. <option value="3">牛肉面</option>
  16. <option value="4">米饭</option>
  17. <option value="5">大盘鸡</option>
  18. </select>

main.js

  

  1. app=new Vue({
  2. el:"#app",
  3. data:{
  4. sex:"boy",
  5. hobby:["Node.js"],
  6. article:" as带回家水电费和水电费水电费会计师的福克斯的发布水电费爱神的箭看哈水电费快捷方式大号爱上的语句告诉大家受到个是的尴尬收到就好\n",
  7. add:5,
  8. food:[1,3,5]
  9. }
  10. })

在下拉选择框select中,在所选的select绑定数据,在data中指定value就可以表现代替选项的文本,在开发中一般是有id代替,而这个选项文本可能会随之改变,而id则是一劳永逸!

v-model小结:使用范围input,textarea和select

转自 十月梦想博客 。
原文地址《一天带你入门到放弃vue.js(一)

相关文章:

一天带你入门到放弃vue.js(一)

一天带你入门到放弃vue.js(二)

一天带你入门到放弃vue.js(三)

一天带你入门到放弃vue.js(一)的更多相关文章

  1. 一天带你入门到放弃vue.js(三)

    自定义指令 在上面学习了自定义组件接下来看一下自定义指令 自己新建的标签赋予特殊功能的是组件,而指定是在标签上使用类似于属性,以v-name开头,v-on,v-if...是系统指令! v-是表示这是v ...

  2. 一天带你入门到放弃vue.js(二)

    接下来我们继续学习一天带你入门到放弃系列vue.js(二),如有问题请留言讨论! v-if index.html <div id="app"> <p v-if=& ...

  3. 5分钟带你入门vuex(vue状态管理)

    如果你之前使用过vue.js,你一定知道在vue中各个组件之间传值的痛苦,在vue中我们可以使用vuex来保存我们需要管理的状态值,值一旦被修改,所有引用该值的地方就会自动更新,那么接下来我们就来学习 ...

  4. 【JavaScript从入门到放弃】JS基础-01

    作为一个前端开发人员,JS是我们行走江湖吃饭的家伙.基本上一个前端人员能值多少大洋,就看JS了.虽然各种框架层出不穷,但是归根结底学好原生JS才是硬道理. 学习任何新东西其实都遵循 10000 小时成 ...

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

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

  6. Vue.js入门

    之前一直用的是jQuery,jQuery手动操作DOM导致性能不够好,因为DOM修改导致的页面重绘.重新排版!重新排版是用户阻塞的操作,同时,如果频繁重排,CPU使用率也会猛涨! Vue.js是数据驱 ...

  7. Vue.js 快速入门

    什么是Vue.js vue是法语中视图的意思,Vue.js是一个轻巧.高性能.可组件化的MVVM库,同时拥有非常容易上手的API.作者是尤雨溪,写下这篇文章时vue.js版本为1.0.7 准备 我推荐 ...

  8. Vue.js + Webpack + ECMAScript 6 入门教程

    Vue.js学习教程 1.Vue.js——60分钟快速入门 2.Vue.js——60分钟组件快速入门(上篇) 3.Vue.js——60分钟组件快速入门(下篇) 4.Vue.js——基于$.ajax实现 ...

  9. day67:Vue:es6基本语法&vue.js基本使用&vue指令系统

    目录 Vue前戏:es6的基本语法 1.es6中的let特点 1.1.局部作用域 1.2.不存在变量提升 1.3.不能重复声明 1.4.let声明的全局变量不从属于window对象,var声明的全局变 ...

随机推荐

  1. JSON.stringify() 和 JSON.parse()

    stringify()用于从一个对象解析出字符串,如 var obj = {x: 1, y: 2 } console.log(JSON.stringify(obj)) //{"x" ...

  2. license.json

    {"license":{"uid":"5359f3d1-8c8c-462b-a17b-b7eb0c3ddb8f","type&qu ...

  3. 驱动调试(一)-printk

    目录 驱动调试(一)-printk 引入 框架 入口console_setup add_preferred_console register_console s3c24xx_serial_initco ...

  4. CMDB服务器管理系统【s5day87】:需求讨论-设计思路

    自动化运维平台愿景和服务器管理系统背景 服务器管理系统 管理后台示例 需求和设计 为什么开发服务器管理系统? 背景: 原来是用Excel维护服务器资产,samb服务[多个运维人员手动维护] 搭建运维自 ...

  5. Windows下配置eclipse写WordCount

    1 下载插件 hadoop-eclipse-plugin-2.7.2.jar github上下载源码后需要自己编译.这里使用已经编译好的插件即可 2 配置插件 把插件放到..\eclipse\plug ...

  6. WPF布局的应用

    一 写在开头1.1 本文内容本文主要内容是使用WPF来实现几个简单的界面. 二 登录窗口小例子2.1 实现代码XAML代码: <Window x:Class="LoginDialog. ...

  7. 第九节:深究并行编程Parallel类中的三大方法 (For、ForEach、Invoke)和几大编程模型(SPM、APM、EAP、TAP)

    一. 并行编程 1. 区分串行编程和串行编程 ①. 串行编程:所谓的串行编程就是单线程的作用下,按顺序执行.(典型代表for循环 下面例子从1-100按顺序执行) ②. 并行编程:充分利用多核cpu的 ...

  8. Java设计模式之抽象工厂

    概述 设计模式(Design Pattern)是一套被反复使用.多数人知晓的.经过分类的.代码设计经验的总结. 使用设计模式的目的:为了代码可重用性.让代码更容易被他人理解.保证代码可靠性. 设计模式 ...

  9. 针对主机CPU idle性能情况需求脚本编写

    [环境介绍] 系统环境:Linux + osw + python 2.7.10 [背景描述] 需求:当系统服务器出现性能告警的时候,需要定位具体的时间点来进行有针对性的去查询产生的问题.OSW提供了很 ...

  10. SQL Server 数据库编程技巧

    Ø  简介 本文主要介绍 SQL Server 数据库在平常的开发中,可能会涉及到的编程技巧,主要包含以下内容: 1.   解决 SQL Server 不支持 127.0.0.1 登录 2.   查询 ...