vue的介绍


渐进式的JavaScript框架

  1. vue react angualr
  2.  
  3. 作者:尤雨溪 facebook 谷歌公司
  4.  
  5. 文档:中文 建议:如果你想学好vue
  6. 1.看视频 初步的了解vue
  7. 2.vue的课 时刻看官网文档 https://cn.vuejs.org/

前端框架和库的区别

功能上的不同

  1. jquery库:包含DOM(操作DOM)+请求,就是一块功能。
  2. art-template库:模板引擎渲染,高性能的渲染DOM (我们后端的一种模板 python的模板类似)
  3. 框架:大而全的概念,简易的DOM体验+请求处理+模板引擎
  4. KFC的世界里,库就是一个小套餐,框架就是全家桶。

代码上的不同

  1. 一般使用库的代码,是调用某个函数或者直接使用抛出来的对象,我们自己处理库中的代码。
  2. 一般使用框架,其框架本身提供的好的成套的工具帮我们运行我们编写好的代码。

框架的使用

  • 初始化自身的一些行为
  • 执行你所编写的代码
  • 释放一些资源

nodejs

  1. 去官网https://nodejs.org/en/download/ 下载 安装(傻瓜式安装)

  2. 打开终端 cmd : 执行node -v 如果出现版本号,证明安装node成功 ,跟安装python雷同

  3. 下载完node之后,会自带包管理器 npm,好比 是python中 pip3包管理器。pip3 install xxx

  4. 使用npm

    1. 1.要初始化npm的项目 :

      npm init --yes 自动生成一个package.json文件

       ```

        javascript

         {

          "name": "vue_lesson",

          "version": "1.0.0", "description": "这是我的vue的第一个项目",

          "main": "index.js",

           "scripts": { "test": "echo "Error: no test specified" && exit 1" },

          "author": "mjj",

          "license": "ISC",

           "dependencies": { "vue": "^2.5.16" }

         }

       ```

     2.下载依赖包

      npm install vue --save
      npm install jquery --save

     3.卸载包 npm uninstall vue --save

     4.下载所有的依赖包 npm install

 

vue的起步

  • 引包:
  • 创建实例化对象
  1. new Vue({
  2. el:'#app',//目的地
  3. data:{
  4. msg:"hello Vue"
  5. }
  6. });
  7. /*
  8. {{}}: 模板语法插值
  9. {{变量}}
  10. {{1+1}}
  11. {{'hello'}}
  12. {{函数的调用}}
  13. {{1==1?'真的':'假的'}}
  14. */

指令系统

  1. //常用
  2. v-text
  3. v-html
  4. v-if
  5. v-show
  6. v-for
  7. v-bind
  8. v-on
  9. 表单控件的value (看后面)

v-if和v-show

  1. v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。
  2. v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。
  3. 相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。
  4. 一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。
  5.  
  6. //保存数组或者对象 格式
  7. v-for = '(item,index) in menuList'
  8. v-for = '(value,key) in object'
  9. //item指的是数组中每项元素
  1. <a href="" class='box'></a>
  2. <img src="" alt="">
  3. 使用v-bind:class = '{}||[]||变量名||常量' 对我们的页面中标签的属性进行绑定 所有的属性都可以进行绑定,注意只要使用了v-bind 后面的字符串一定是数据属性中的值

### v-on、v-bind、v-for

  1. // 1.事件源 2.事件 3.事件驱动程序
  2. vue中使用v-on:click对当前DOM绑定click事件 注意:所有的原生js的事件使用v-on都可以绑定
  3.  
  4. v-ifv-on 来对页面中DOM进行操作
  5.  
  6. v-bind:classv-on对页面中DOM的样式切换
  7.  
  8. v-bindv-on
  9.  
  10. vue中它可以简写: v-bind:
  11. :class 等价于 v-bind:class
  12. :src 等价于v-bind:src
  13. :id 等价于v-bind:id
  14. v-on:click 等价于 @click = '方法名'
  1. v-text v-html {{}}: 对页面的dom进行赋值运算 相当与jsinnerText innerHTML
  2.  
  3. v-if = 'true':
  4. //创建
  5. var oP = document.createElement('p') ;
  6. oDiv.appendChild(op)
  7.  
  8. v-if = 'false'
  9. //销毁
  10. oDiv.removeChild(op)
  11. v-show = 'true'
  12. oDiv.style.display = 'block'
  13. v-show:'true'
  14. oDid.style.display = 'none'
  15.  
  16. v-bind:class
  17. oDiv.className += ' active'
  18.  
  19. /*
  20. 渐进式的JavaScript框架
  21. 做加法和做减法:大部分的人觉得做加法简单,做减法难
  22. vue这个框架 将 做减法的事情都给咱们做了(难的部分)
  23. 学习简单的部分就能实现复杂的dom操作
  24. */

组件的使用

局部组件的使用

​ 打油诗: 1.声子 2.挂子 3.用

  1. var App = {
  2. tempalte:`
  3. <div class='app'></div>`
  4. };
  5.  
  6. //2.挂子
  7.  
  8. new Vue({
  9. el:"#app",
  10. //用子
  11. template:<App />
  12. components:{
  13. App
  14. }
  15.  
  16. })

(1)父组件向子组件传递数据:通过Prop

  1. 1.在子组件自定义特性。props:['自定义的属性1','自定义属性2']
  2.  
  3. 当一个值传递给一个 prop 特性的时候,它就变成了那个组件实例的一个属性,那么我们就可以像访问data中的值一样
  4. 2.要在父组件中导入的子组件内部 绑定自定义的属性 <Vheader :title = '父组件中data声明的数据属性'/>

(2)如何从子组件传递数据到父组件

  1. 1.给子组件中的某个按钮绑定原声事件,。我们可以调用内建的 this.$emit('自定义的事件名','传递的数据'),来向父级组件触发一个自定义的事件.
  2.  
  3. 2.在父组件中的子组件标签中 要绑定自定义的事件,

全局组件的使用

  1. Vue.component('全局组件的名字',{
  2. new Vue() 实例化对象中的options是一样,但是要注意:
  3. 不管是公共组件还是局部组件 data必须是个函数 函数一定要返回 {}
  4. })
  1. <slot> 元素作为承载分发内容的出口

过滤器的使用

局部过滤器

  1. //1.注册局部过滤器 在组件对象中定义
  2. filters:{
  3. '过滤器的名字':function(value){
  4. }
  5. }
  6. //2.使用过滤器 使用管道符 |
  7. {{price | '过滤器的名字'}}

全局过滤器

  1. // 注册全局的过滤器
  2. //第一个参数是过滤器的名字,第二个参数是执行的操作
  3.  
  4. Vue.filter('reverse',function(value) {
  5. return value.split('').reverse().join('');
  6. });
  7.  
  8. //使用跟 局部过滤器一样

计算属性computed和侦听器(watch)

侦听的是单个属性

  1. watch:{
  2.  
  3. 数据属性的名字:function(value){
  4.  
  5. },
  6. 数据属性的名字2function(value){
  7.  
  8. }
  9. }

 

侦听多个属性:计算属性 computed

  1. {{str.split('').reverse().join('')}}
  1. 计算属性 :默认只有getter方法
  2.  
  3. data(){
  4.  
  5. return {
  6.  
  7. name:'alex',
  8.  
  9. age:18
  10.  
  11. }
  12.  
  13. }
  14.  
  15. compuetd:{
  16.  
  17. key:value
  18.  
  19. 计算属性的方法名:funtion(){
  20.  
  21. return ${this.name}他的年龄是${this.age}岁
  22.  
  23. }
  24.  
  25. }
  26.  
  27. var musicData = [
  28.  
  29. {
  30.  
  31. id:1,
  32.  
  33. name:'于荣光 - 少林英雄',
  34.  
  35. author:'于荣光',
  36.  
  37. songSrc:'./static/于荣光 - 少林英雄.mp3'
  38.  
  39. },
  40.  
  41. {
  42.  
  43. id:2,
  44.  
  45. name:'Joel Adams - Please Dont Go',
  46.  
  47. author:'Joel Adams',
  48.  
  49. songSrc:'./static/Joel Adams - Please Dont Go.mp3'
  50.  
  51. },
  52.  
  53. {
  54.  
  55. id:3,
  56.  
  57. name:'MKJ - Time',
  58.  
  59. author:'MKJ',
  60.  
  61. songSrc:'./static/MKJ - Time.mp3'
  62.  
  63. },
  64.  
  65. {
  66.  
  67. id:4,name:'Russ - Psycho (Pt. 2)',
  68.  
  69. author:'Russ',
  70.  
  71. songSrc:'./static/Russ - Psycho (Pt. 2).mp3'
  72.  
  73. }
  74.  
  75. ];

生命周期(钩子函数)

  1. beforeCreate(){
  2.  
  3. // 组件创建之前
  4.  
  5. console.log(this.msg);
  6.  
  7. },
  8.  
  9. created(){
  10.  
  11. // 组件创建之后
  12.  
  13. // 使用该组件,就会触发以上的钩子函数,created中可以操作数据,发送ajax,并且可以实现vue==》页面的影响 应用:发送ajax请求
  14.  
  15. console.log(this.msg);
  16.  
  17. // this.msg = '嘿嘿黑';
  18.  
  19. },
  20.  
  21. beforeMount(){
  22.  
  23. // 装载数据到DOM之前会调用
  24.  
  25. console.log(document.getElementById('app'));
  26.  
  27. },
  28.  
  29. mounted(){
  30.  
  31. // 这个地方可以操作DOM
  32.  
  33. // 装载数据到DOM之后会调用 可以获取到真实存在的DOM元素,vue操作以后的DOM
  34.  
  35. console.log(document.getElementById('app'));
  36.  
  37. },
  38.  
  39. beforeUpdate(){
  40.  
  41. // 在更新之前,调用此钩子,应用:获取原始的DOM
  42.  
  43. console.log(document.getElementById('app').innerHTML);
  44.  
  45. },
  46.  
  47. updated(){
  48.  
  49. // 在更新之前,调用此钩子,应用:获取最新的DOM
  50.  
  51. console.log(document.getElementById('app').innerHTML);
  52.  
  53. },
  54.  
  55. beforeDestroy(){
  56.  
  57. console.log('beforeDestroy');
  58.  
  59. },
  60.  
  61. destroyed(){
  62.  
  63. console.log('destroyed');
  64.  
  65. },
  66.  
  67. activated(){
  68.  
  69. console.log('组件被激活了');
  70.  
  71. },
  72.  
  73. deactivated(){
  74.  
  75. console.log('组件被停用了');
  76.  
  77. }

$属性

  • $refs获取组件内的元素
  • $parent:获取当前组件的父组件
  • $children:获取当前组件的子组件
  • $root:获取New Vue的实例化对象
  • $el:获取组件对象的DOM元素

获取更新之后的dom添加事件的特殊情况

  1. $nextTick 是在下次Dom更新循环结束之后执行的延迟回调,在修改数据之后使用$nextTick ,则可以在回调中获取更新之后的DOM

 

 

  

07-Vue的基础使用的更多相关文章

  1. Vue学习记录第一篇——Vue入门基础

    前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...

  2. Vue组件基础用法

    前面的话 组件(Component)是Vue.js最强大的功能之一.组件可以扩展HTML元素,封装可重用的代码.根据项目需求,抽象出一些组件,每个组件里包含了展现.功能和样式.每个页面,根据自己所需, ...

  3. 一个综合实例讲解vue的基础知识点。

    本文通过一个简单的实例来讲解一下vue的基本知识点.通过这个综合实例的讲解,vue的基础知识就会掌握的差不多了. 首先看一下项目的效果:

  4. Vue入门基础

    前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...

  5. Vue组件基础

    <!DOCTYPE html><html>    <head>        <meta charset="utf-8">      ...

  6. react router @4 和 vue路由 详解(一)vue路由基础和使用

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 1.vue路由基础和使用 a.大概目录 我这里建了一个router文件夹,文件夹下有in ...

  7. Vue入门基础(火柴)

    前言 由于个人十分欣赏博友——小火柴的蓝色理想,他的博文我看了大多数,觉得十分的精彩,然而很多都是看后即忘.我想除了没有经常动手敲代码,更可能是在看的时候忽略了很多细节,因此打算把他的博文通通给“抄袭 ...

  8. Django 07 Django模型基础2 (常用查询和多表关联)

    Django 07 Django模型基础2 (常用查询和多表关联) 一.常用查询 #查找数据 def search_user(request): #获取 rs = User.objects.first ...

  9. vue组件基础之父子传值

    可以看出数据从后端获取过来,最外层的父组件接收数据,子组件不能直接获取,必须由父组件传递,此时使用props,并且父组件的值更新后,子组件的值也会随之更新,但是反过来通过修改子组件props来影响父组 ...

  10. vue入门基础知识点测试

    vue入门基础知识点测试 1.文本(值绑定){{var}}----控制<div></div>的值显示当前时间,且1秒更新一次.(可查阅 setinterval 函数,时间Dat ...

随机推荐

  1. [Swift]LeetCode466. 统计重复个数 | Count The Repetitions

    Define S = [s,n] as the string S which consists of n connected strings s. For example, ["abc&qu ...

  2. Java-SSM框架页面时间格式转换

    在JSP中,列表查询绑定时间时,会出现以下的时间格式,那样看起来的话,感觉... 那如何转换成“yyyy-MM-dd HH:mm:ss”格式呢?--很简单,在JSP头顶加上 <%@ taglib ...

  3. Redis面试题

    1.谈谈Redis的主从复制流程 有几个重点:主节点负责写,从节点负责读,slave node 主要用来进行横向扩容,做读写分离,扩容的 slave node 可以提高读的吞吐量.必须开启 maste ...

  4. Spring设计模式_策略模式/其他

    策略模式特性 1.执行最终结果一样 2.执行过程和执行逻辑不一样 3.使用同一接口 达到目的就可以了 Git地址 https://github.com/wujiachengSH/WjcStrategy ...

  5. C++ 断言

    assert宏 (基本概念与用法整理) assert宏的深入学习 1.运行时断言 1.1.assert属于运行时断言,可以在运行时判断给定条件是否为真,如果为真则什么也不做,否则打印一跳错误信息,然后 ...

  6. 使用ML.NET实现情感分析[新手篇]

    在发出<.NET Core玩转机器学习>和<使用ML.NET预测纽约出租车费>两文后,相信读者朋友们即使在不明就里的情况下,也能按照内容顺利跑完代码运行出结果,对使用.NET ...

  7. HBase2实战:HBase Flink和Kafka整合

    1.概述 Apache官方发布HBase2已经有一段时间了,HBase2中包含了许多个Features,从官方JIRA来看,大约有4500+个ISSUES(查看地址),从版本上来看是一个非常大的版本了 ...

  8. 记一次查询超时的解决方案The timeout period elapsed......

    问题描述 在数据库中执行查询语句,大约1秒钟查询出来,在C#中用ado进行连接查询,一直等待很久未查出结果,最后抛出查询超时异常. 异常内容如下: Execution Timeout Expired. ...

  9. web进修之—Hibernate起步(1)(2)

    想开始写博客了,尝试了CSDN和cnblog之后还是觉得cnblog更加简洁.专注(不过cnblog不支持搬家),所以把刚刚写的两篇学习博客链接放在这儿,这样这个系列也算是完整了: web进修之—Hi ...

  10. Java开发知识之Java的异常处理

    Java开发知识之Java的异常处理 一丶异常概述 在讲解异常之前,我们要搞清楚.什么是异常. 通俗理解就是我们编写的程序出问题了.进行处理的一种手段. 比如我们的QQ.有的时候就崩溃了.比如出现xx ...