初识vue ——总结

Vue 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。

Vue 特点:简单、易学、更轻量

Vue中常用指令

v-model ::双向数据绑定,一般用于表单元素
v-for :对数组或者对象进行循环操作
v-on :用来绑定事件,用法:v-on:事件="函数"
v-show :用来显示或者隐藏元素,实质是通过display实现
v-if
...

事件

  • 1 事件简写
    v-on:事件,简写成:@事件名
  • 2 事件对象
    vue里面的事件对象使用event; 这个event包含了事件事件相关的信息,如事件源、事件类型、偏移量等等...


    如:点击按钮,将对应按钮的文字返回给我

    <div id="app" >
        <input type="button" value="点我" @click="print($event)">
    </div>
    <script src="vue.js"></script>
    <script type="text/javascript">
        window.onload = function(){
            var vue = new Vue({
                el:"#app",
                methods:{
                    print(event){
                        console.log(event.target.value); 
                    }
                }
           });
    </script>

属性

  • 1 属性的绑定和简写
    v-bind用于属性绑定,
    格式v-bind:属性="",可简写为:属性=""
  • 2 class和style属性
    比如:

    <div id="app">
      <div :class="{ active: isActive }"></div>
    </div>

模板

  • 简介
    Vue使用基于HTML的模板语法,可以将DOM绑定到Vue实例中的数据模板就是{{}},用来进行数据绑定,显示在页面中,这种{{}}(和Angular相同)。
  • 数据的绑定方式
    1 双向绑定 :v-model
    2 单项绑定 :使用{{}}。
  • 其他指令
    v-once 数据只绑定一次
    v-pre 直接原样显示

过滤器

Angular用法相同

<!-- 在双花括号中 --> 
{{ message | capitalize }}
<!-- 在 `v-bind` 中 --> 
<div v-bind:id="rawId | formatId"></div>

Vue1.0中内置了许多过滤器,如:

capitalize   首字母大写
uppercase    全部大写
lowercase    全部小写
currency     输出金钱以及小数点
pluralize    变复数
... 

在Vue2.0中已经移除了所有内置过滤器。
解决方案:
(1)使用第三方工具库:如loadash、date-fns日期格式化、accounting货币格式化;
(2)使用自定义过滤器;

生命周期

  • Vue2.0的生命周期钩子

    生命周期钩子 说明
    beforCreate 实例初始化完成
    created 实例化已经完成之后被调用,数据观测,属性和方法的运算,watch/event事件回调已完成,挂载还没还没开始 $el属性上还没有
    beforeMount 开始挂载之前调用,相关的render函数首次被调用 此时的DOM是数据挂载前的DOM,数据还未挂载
    mounted 数据已挂载后调用 初始化的el被vm.$el替换,并挂载到实例上去之后的钩子
    beforeUpdate 数据更新时调用,发生在虚拟DOM重新渲染和打补丁之前
    updated 在数据驱动下导致的虚拟DOM重新渲染和打补丁之后调用,此时,组件DOM已经更新
    activated keep-alive 组件激活时调用如果你使用keep-alive进行缓存, 又希望每次切换组件的时候更新数据,那么更新数据的请求方式必须写在该钩子函数里
    deactivated keep-alive 组件停用时调用
    beforeDestroy 实例销毁之前调用,此时实例还可用
    destroyed 实例销毁后调用,实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁
  • 官方给出的生命周期图示

    Vue 实例生命周期



  •  var vue = new Vue({
        el:"#app",
        beforeCreate:function(){
            //创建前
            console.log('beforeCreate');
        },
        created: function(){
           // 创建完成后
           console.log('created');
        },
        beforeMount:function(){
            //加载前
            console.log('beforeMount');
        },
        mounted:function(){
            //加载后
            console.log('mounted');
        },
        beforeUpdate:function(){
            //更新前
            console.log('beforeUpdate');
        },
        updated:function(){
            //更新后
            console.log('updated');
        },
        beforeDestroy:function(){
            //销毁前
            console.log('beforeDestroy');
        },
        destroyed:function() {
            //销毁后
            console.log('destroyed');
        }
    });

总结

官方没有给出Demo不是很友好

多学点总是好的!! ———— 致自己


我的人生成长之路
Good good study, day day up!

为 API 生,为框架死,为 debug 奋斗一辈子;

889 声望
33 粉丝
0 条评论
推荐阅读
微信JSAPI支付 (签名问题)
jsapi微信底层就不过多描述了,主要记录一下,查了很多资料,发现微信返回参数不能直接返给前端使用,还需要进行一次签名,不然前台就会提示签名错误

潘佳琦阅读 310

ESlint + Stylelint + VSCode自动格式化代码(2023)
安装插件 ESLint,然后 File -&gt; Preference-&gt; Settings(如果装了中文插件包应该是 文件 -&gt; 选项 -&gt; 设置),搜索 eslint,点击 Edit in setting.json

谭光志34阅读 20.8k评论 9

vue UI框架比较
最好基于vue2.0PC端:因为用过的是饿了么UI,所以比较以饿了么UI为基础element UI 饿了么UI支持vue2.x80分优点:组件的API方法、属性等封装的较为完善缺点:样式有些生硬,不够炫酷美观N3 N3支持vue2.x70分优点:...

chinawzc22阅读 39.9k评论 17

Vue2 导出excel
2020-07-15更新 excel导出安装 {代码...} src文件夹下新建一个libs文件夹,新建一个excel.js {代码...} vue页面中使用 {代码...} ===========================以下为早期的文章今天在开发的过程中需要做一个Vue的...

原谅我一生不羁放歌搞文艺14阅读 20k评论 9

用了那么久的 SVG,你还没有入门吗?
其实在大部分的项目中都有 直接 或 间接 使用到 SVG 和 Canvas,但是在大多数时候我们只是选择 简单了解 或 直接跳过,这有问题吗?没有问题,毕竟砖还是要搬的!

熊的猫17阅读 1.6k评论 2

封面图
嘿,vue中keep-alive有个「大坑」你可能还不知道
背景是这样的,我们使用vue2开发一个在线客服使用的IM应用,基本布局是左边是访客列表,右边是访客对话,为了让对话加载更友好,我们将对话的路由使用&lt;keep-alive&gt;缓存起来。但是如果将所有对话都缓存,未...

wuwhs12阅读 2.6k

封面图
你可能需要的多文档页面交互方案
在日常工作中,面对不同的需求场景,你可能会遇到需要进行多文档页面间交互的实现,例如在 A 页面跳转到 B 页面进行某些操作后,A 页面需要针对该操作做出一定的反馈等等,这个看似简单的功能,却也需要根据不同...

熊的猫8阅读 1.3k

封面图

为 API 生,为框架死,为 debug 奋斗一辈子;

889 声望
33 粉丝
宣传栏