vue学习的第一天小结

## Vue官网

官网:https://cn.vuejs.org/

命令行:https://cli.vuejs.org/zh/

## Vue安装流程

1.npm install -g @vue/cli

# OR

yarn global add @vue/cli

2.npm install -g @vue/cli-init

# `vue init` 的运行效果将会跟 `vue-cli@2.x` 相同

vue init webpack my-project

3.vue init webpack project-name

4.npm run dev-> http://localhost:8080

## vue

是一个  MVVM 前端 渐进式的 用户构建用户界面的 js框架

    M V VM 

一切以数据为核心 不要想着去操作dom

M 数据

V 视图

MVVM 数据和视图式双向绑定的,数据改变视图会自动刷新(视图也可以直接改变数据)

命令式

    比如jquery

声明式

    比如vue

## Vue和原生js不互通的  

如何打通 methods中的 方法  中  是可以写 任意原生代码

## vue模板的语法  {{}}  渲染数据

```

{{}}

模板 用于 渲染  数据

注意:

    1, 模板内部 是js环境 (渲染具体的值,如果是字符串别忘了引号)

    2,模板内部可以计算

    3,渲染值,所以不能写语句,但是可以写表达式 如三目  短路

    4,内部出现的变量 会自动解析为 vue实例下的 属性或者方法

        js全局的 方法 不能调用(除非 vue模板白名单下的js全局方法可以调用)

        'Infinity,undefined,NaN,isFinite,isNaN,' +

        'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' +

        'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' +

        'require'

        注意:data或者methods中的属性和方法 注意区别这些白名单中的变量名

```

## 短路

    如果前面一个表达式 已经得出最终的结论,那么后面一个表达式就不执行,否则执行后面一个表达式

    可以用 && 和 || 做短路

    && 类似于  if结构

    一个 条件满足就执行不满足就不执行

    1>2&&alert(1)

    var e = ev||event;


    btn.onclick = function(ev){

        var e = ev||event;

    }

vue:

    mvvm

    渐进式

    构建用户界面 框架

框架、库:

雏形:

```

script src ='vue.js'

script

    div #app

        {{ msg }}

    let vm = new Vue({

        el:"#app",

        data:{

            msg:"hello vue"

        },

        methods:{

        }

    })

```

*********************************************************

## vue外部挂载

```

        let vm = new Vue({

            data:{

                msg:"hello vue"

            }

        })

        vm.$mount(document.querySelector("#app"))

```

## vue指令

扩展了 标签 属性的功能

用法:同属性

    v-指令名

+ v-model

    将表单 控件 的值 与 一个 数据(状态),进行绑定(双向)

+ v-text  不用记 将元素的  内容  与 一个  数据进行绑定

+ v-html 解析富文本数据

总结:

    1,指令的值  同模板中的环境

        1,是js环境 字符串 需加引号

        2,变量会自动去找实例上的属性或者方法

        3,可以写 计算

        4,可以写表达式 不可以写 if分支结构

+ v-bind:属性   属性 是 标签自己的属性 或者自定义属性(可以是任意的标签的属性)

    将 这个属性  变成一个 动态的属性

    将属性的值变成了

        1,是js环境 字符串 需加引号

        2,变量会自动去找实例上的属性或者方法

        3,可以写 计算

        4,可以写表达式 不可以写 if分支结构

    简写:    

        :属性

+ v-on:事件   将普通的事件  变成 动态事件(与vue实例上的方法进行绑定)

    简写:

        @事件名

    如何获取事件源

```

<div @click ="fn">  // fn是事件函数

{

    methods:{

        fn(e){ // 第一个参数 就是 事件对象

            //取消冒泡 阻止默认事件  

        }

    }

}

如果这样写

<div @click ="fn($event)">  // fn不在是事件函数 有时 调用 方法时需传参数

vue提供了 挂载到 Vue.prototype上的属性 叫$event 保存了事件对象

{

    methods:{

        fn(e){ // 第一个参数 就是 事件对象

            //取消冒泡 阻止默认事件  

        }

    }

}

```

## 事件修饰符

功能 修饰一个事件 实现如(取消冒泡、阻止默认事件啊...功能)

@事件名.修饰符

```

.stop

.prevent

.capture

.self

.once

```

## 条件渲染

v-if条件渲染

    将元素 渲染(显示、消失)和一个变量的值绑定,值为true显示,否则消失

v-else模块  注意:v-if条件取反(一定是v-if下一个兄弟)

v-show

v-if和v-show区别:

    1,元素 隐藏 v-show 元素 display:none   v-if直接移除元素

    2,初始值为false时, v-if是惰性的 初始元素是 不加载

    使用场景:

        1,v-show适用于 频繁显示、隐藏 场景

        2,v-if适用于 不频繁显示、隐藏,且内部结构比较复杂(惰性,可以提高首次打开速度)

## 列表渲染

v-for

```

        <ul>

           <li v-for="fruit in arr">

               {{ fruit }}

           </li>

       </ul>

       <hr>

       <ul>

           <li v-for="(fruit,index) in arr"> //加key

               {{index}}  =>

               {{ fruit }}

           </li>

       </ul>

       <hr>

       循环json

       <ul>

           <li v-for="el in json"> // 循环json

               {{ el }}

           </li>

       </ul>

       <hr>

       <ul>

        <li v-for="(el,key,index) in json"> //循环json 并加 key 和index

            {{ key }}

            =>

            {{ index }}

            =>

            {{ el }}

        </li>

    </ul>

注意:

    循环每一项  应该加上一个 独一无二的 key(属性 属性值要求独一无二)

```

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353