Vue.js 基本功能了解

一、写在前面

  隔了这么久才来出Vue的第二篇文章,真是堕落了,自己先惩罚下/(ㄒoㄒ)/~~
  回过头看自己第一篇相关文章《初试 Vue.js》(http://www.cnblogs.com/anniey/p/6307138.html),简直惨不忍睹、不忍直视、辣眼睛,怎么可以这么啰嗦,废话好多哦,没脸看下去了~(o′?ェ?`o)
  都说入一门语言写好hello wrold开始,我上篇文章就已经打好这个头啦,不管是Vue1,还是2,现在咱们继续╰(*°▽°*)╯

二、起步

  1.简单的方式
    创建好一个html文件,通过script的方式引入,如下:
    <script src="https://unpkg.com/vue"></script>
  2.其他的方式
    参考官网给出的选项:
    https://cn.vuejs.org/guide/installation.html

三、数据的渲染

  Vue.js的核心是采用简洁的模板语法来声明式的将数据渲染进DOM!

  例1:

<div id="app">{{ message }}</div>
1   <script type="text/javascript">
2         var app=new Vue({
3             el:"#app",
4             data:{
5                 message:"hello vue"
6             }
7         })
8     </script>

  这已经生成了一个vue应用,现在数据和DOM已经绑定在一起,只要修改app.message,相应的也会更新DOM!

  例2:

    <div id="app_2">
        <span v-bind:title="message">
            Hover your mouse over me for a few seconds to see my dynamically bound title!
        </span>
    </div>
1     <script type="text/javascript">
2         var app_2=new Vue({
3             el:‘#app_2‘,
4             data:{
5                 message:‘You loaded this page on ‘+new Date()
6             }
7         })
8     </script>

  例子2涉及到了Vue的特殊属性 v-bind 指令,也会在相应的DOM元素上渲染!

四、条件与循环

  Vue不仅可以绑定DOM文本到数据,也可以绑定DOM结构到数据!

  1.条件

    我们可以使用其中的 v-if 指令达到条件设置,而在实际应用中控制切换一个元素的显示也很简单。

    例3:

1     <div id="app_3">
2         <p v-if="flags">Now you see me</p>
3     </div>
1     <script>
2         var app_3=new Vue({
3             el:‘#app_3‘,
4             data:{
5                 flags:true
6             }
7         })
8     </script>

    同样的可以修改data属性来达到响应。

  2.循环

    每个指令都有特殊的功能,v-for 指令可以绑定数组的数据来渲染一个列表!

    例4:

1     <div id="app_3_2">
2         <ul>
3             <li v-for="todo in todos">
4                 {{todo.text}}
5             </li>
6         </ul>
7     </div>
 1     var app_3_2=new Vue({
 2             el:‘#app_3_2‘,
 3             data:{
 4                 todos:[
 5                     { text:‘Learn JavaScript‘ },
 6                     { text:‘Learn Vue‘ },
 7                     { text:‘Learn Other ‘ }
 8                 ]
 9             }
10         })

  打开控制台,输入 app_3_2.todos.push({ text: ‘新项目‘ }),你会发现列表中添加了一个新项。

五、双向绑定

  Vue 提供了一个  v-model 指令,它能轻松实现表单输入和应用状态之间的双向绑定。

  例5:

1     <div id="app5">
2         <input type="text" v-model="msg2" />
3         <p>{{msg2}}</p>
4     </div>
1     var app5 = new Vue({
2         el: ‘#app5‘,
3         data: {
4           msg2: ‘# hello ‘
5        }
6     })

六、界面交互

  为了让用户和你的应用进行互动,我们可以用  v-on  指令绑定一个事件监听器,通过它调用我们 Vue 实例中定义的方法!

  例6:

1     <div id="app6">
2         <p>{{message}}</p>
3         <button v-on:click="reverseMessage">Reverse Message</button>
4     </div>
 1     var app6=new Vue({
 2             el:‘#app6‘,
 3             data:{
 4                 message:‘Hello Vue.js!‘
 5             },
 6             methods:{
 7                 reverseMessage:function(e){
 8                     this.message=this.message.split(‘‘).reverse().join(‘‘);
 9                 }
10             }
11         })

  注意:在methods方法中,只更新了状态,没有触动到DOM!

七、组件构建(简单版)

  一定要先注册完组件,再来实例化!

  一定要确保在初始化根实例之前注册了组件!

  否则未注册就使用会报错的!  

  组件比较强大,可以扩展,封装可重用代码,就是比较腻害(*@ο@*) 哇~一定要好好的熟悉熟悉它!

 例7:

1     <div id="app_7">
2         <ol>
3             <todo-item v-for="list in itemsList" v-bind:todo="list"></todo-item>
4         </ol>
5     </div>
 1     Vue.component(‘todo-item‘,{
 2             props:[‘todo‘],
 3             template:‘<li>{{todo.text}}</li>‘
 4         });
 5         var app_7=new Vue({
 6             el:‘#app_7‘,
 7             data:{
 8                 itemsList:[
 9                     {text:‘Vegetables‘},
10                     {text:‘Cheese‘},
11                     {text:‘Whatever else humans are supposed to eat‘}
12                 ]
13             }
14         })

  组件是很重要的一部分,当你熟悉完以上的内容后要好好研究组件系统,其中涉及到许多内容需要更详细的掌握。

  在实际项目中使用时,多个页面有相同的part,组件复用简直厉害的不要不要~O(∩_∩)O~~

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

vue的基本功能介绍就到这里了,谢谢思密达O(∩_∩)O~~

多多指教n(*≧▽≦*)n

时间: 2024-10-10 10:26:30

Vue.js 基本功能了解的相关文章

Vue.js 很好,但会比 Angular 或 React 更好吗?

文章转自:http://www.oschina.net/translate/vuejs-is-good-but-is-it-better-than-angular-or-rea Vue.js 是一个用来构建网页界面的 JavaScript 库.同其它的一些工具结合在一起,它也可以成为一个新“框架”.通过阅读我们最近一次在ValueCoders 上发表的 文章, 你会了解到 Vue.js 是顶级的 JavaScript 框架之一,它在许多场景中可以被用来替换 Angular 和 React.这就引

热烈庆祝《Vue.js 实战教程 V2.x(一)基础篇》上线了!

课程简介 课程地址:https://ke.qq.com/course/432961 机构名称:大华软件学院 授课讲师:大强老师 课程名称:Vue.js 实战教程 V2.x(一)基础篇 课程简介:包括前端发展史.Vue.js简介.第一个Vue.js程序.安装环境和Vue.Vue实例.模板语法.计算属性和侦听器.Class与Style绑定.条件渲染.列表渲染.事件处理.表单输入绑定.组件基础等等. 适合人群: 1.初出茅庐,想学习前端开发的同学: 2.没用过Vue.js,想学习更多框架的同学: 3.

Vue.js 开发实践:实现精巧的无限加载与分页功能

https://segmentfault.com/a/1190000005351971#articleHeader9 本篇文章是一篇Vue.js的教程,目标在于用一种常见的业务场景--分页/无限加载,帮助读者更好的理解Vue.js中的一些设计思想.与许多Todo List类的入门教程相比,更全面的展示使用Vue.js完成一个需求的思考过程:与一些构建大型应用的高阶教程相比,又更专注于一些零碎细节的实现,方便读者快速掌握.致用. 需求分析 当一个页面中信息量过大时(例如一个新闻列表中有200条新闻

一周一个小demo — vue.js实现备忘录功能

这个vue实现备忘录的功能demo是K在github上找到的,K觉得这是一个用来对vue.js入门的一个非常简单的demo,所以拿在这里共享一下. (尊重他人劳动成果,从小事做起~  demo原github地址:https://github.com/vuejs/vue) 一.实现效果 二.代码展示 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>备忘录&l

[DIV/CSS] Vue.js 开发实践:实现精巧的无限加载与分页功能

本篇文章是一篇Vue.js的教程,目标在于用一种常见的业务场景--分页/无限加载,帮助读者更好的理解Vue.js中的一些设计思想.与许多Todo List类的入门教程相比,更全面的展示使用Vue.js完成一个需求的思考过程:与一些构建大型应用的高阶教程相比,又更专注于一些零碎细节的实现,方便读者快速掌握.致用. 需求分析 当一个页面中信息量过大时(例如一个新闻列表中有200条新闻需要展示),就会产生问题,例如: 数据量过大,影响加载速度 用户体验差,很难定位到之前自己看过的某篇文章 扩展性差,如

VUE.JS实现购物车功能

购物车是电商必备的功能,可以让用户一次性购买多个商品,常见的购物车实现方式有如下几种: 1. 用户更新购物车里的商品后,页面自动刷新. 2. 使用局部刷新功能,服务器端返回整个购物车的页面html 3. 服务器端返回JSON格式,使用模板引擎+dom操作更新页面 最近新学习了vue.js,一个轻量级的mvvm(Model-View-ViewModel),vue.js是数据驱动无须操作dom,它提供特殊的html语言,把dom和数据绑定在一起,一旦修改了数据,dom将会自动更新更新. 关于vue.

vue.js核心最基本的功能

Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统: <div id="app"> {{ message }}</div> var app = new Vue({ el: '#app', data: { message: 'Hello Vue!' }}) 除了文本插值,我们还可以像这样来绑定元素特性: <div id="app-2"> <span v-bind:title="me

Vue.js与 ASP.NET Core 服务端渲染功能整合

http://mgyongyosi.com/2016/Vuejs-server-side-rendering-with-aspnet-core/ 原作者:Mihály Gy?ngy?si 译者:oopsguy.com 我真的很喜欢在前端使用 Vue.js,Vue 服务端渲染直到第二个版本才被支持. 在本例中,我想展示如何将 Vue.js  服务端渲染功能整合 ASP.NET Core. 我们在服务端使用了 Microsoft.AspNetCore.SpaServices 包,该包提供 ASP.N

vue.js实战——购物车练习(包含全选功能)

vue.js实战第5章 54页的练习1 直接放代码好了,全选的部分搞了好久,代码好像有点啰嗦,好在实现功能了(*^▽^*) HTML: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-sca