vue3

Promise

Promise出现的原因: 就是为了解决回调地狱问题(将回调函数的写法进行了更新,之前是传参现在可以通过then)

Promise的使用

Promise的状态说明

  1. pendding: 异步操作还未结束

  2. fullfilled / resolved: 异步操作已经结束并且成功了

  3. rejected : 异步操作已经结束并且失败了

  4. 别人提供的Promise的api我们可以直接使用then方法来写回调!

axios().then(res=>{})
  1. 我们可以通过Promise来给别人提供相应的回调函数的改进写法
function timeOut(time){
    return new Promise(function(resolve, reject){
        //resolve就是将当前promise对象的状态更改为成功, 会调用then里面的第一个函数
        //reject就是将当前promise对象的状态更改为失败,会调用then里面的第二个函数,或者catch里的函数
        setTimeout(function(){
            resolve();
        }, time);
    })
}

timeOut(1000).then(_=>console.log("1s后做的事情"))

自定义指令

指令的基本格式

指令名:参数.修饰符="表达式"

自定义指令什么时候用?

在Vue中如果遇到需要进行DOM操作的情况,就使用自定义指令

如何注册自定义指令

  1. 全局注册
Vue.directive("指令名不带v-", {
    bind(el, binding){
        //el 就是当前指令所在的元素dom对象
        //binding: 就是和指令相关的所有的信息(上面的指令的格式中的所有的内容)
            //指令名: binding.name  binding.rawName
            //参数: binding.arg
            //修饰符: binding.modifiers 
            //表达式:binding.expression
            //表达式的值: binding.value
    },
    inserted(){},
    update(){},
    componentUpdated(){},
    unbind(){}
})


//平时使用的时候 并不一定5个钩子都会用到,最常用的是bind和update
//所以下面的简写形式,就是同时设置了bind和update两个钩子函数
Vue.directive("指令名不带v-", function(){})
  1. 局部注册
var vm = new Vue({
    directives: {
        "指令名": {},
        "指令名": function(){}
    }
})

自定义指令练习(3遍!!)

自定义过滤器

概念??

过滤器可以接收一个数据,并且加工之后返回一个新的数据
本质就是一个函数,接收参数,并且有返回值

html中如何用??

{{data | 过滤器名称(arg1...argN)}}

如何注册过滤器

Vue.filter("过滤器名称", function(value, arg1...argN){
    //value指的就是|前面的内容,也就是要被过滤的内容
    //arg1...argN就是过滤器名称后面传入的参数
    //过滤器一定要有返回值
})

var vm = new Vue({
    filters:{
        "过滤器名称": function(value, arg1...argN){

        }
    }
})

过渡

过渡的6个状态

进入前 进入时 进入后
离开前 离开时 离开后

实现方式

  1. 自定义类样式实现
    1.1 在css样式表中,添加6个类样式 name-enter name-enter-to name-enter-active
    name-leave name-leave-to name-leave-active
    1.2 在要实现过渡的元素上包裹一个transition标签,将name设置为类样式开头的name,如果不设置name,默认会找v-打头的类样式

  2. 第三方css库实现

    <transition enter-active-class="animated tada" leave-active-class="animated bounceOutRight">
        <div></div>
    </transition>
    
  3. js钩子函数实现
    3.1 8个钩子函数
    before-enter
    enter
    after-enter
    enter-cancelled
    before-leave
    leave
    after-leave
    leave-cancelled

    3.2 一般我们会在 before-enter中设置进入前的样式 enter中设置进入后以及过渡时的样式, enter中需要先触发一次重绘 el.offsetWidth

单页面应用

本质: 根据hash值的改变,切换显示页面中的内容!!

练习(自己实现一个简单的单页面应用!)

组件

组件化

将页面按照功能,进行拆分,创建成组件,每需要一个页面的时候,只需要把创建好的组件拿过来组装成一个新的页面即可

组件

包含html,css,js的功能代码!

组件的注册

    Vue.component("组件名(不能用驼峰命名)", {
        template: "html模板字符串",
        data(){
            return {
                // 这里就是数据
            }
        }
    })

    var vm = new Vue({
        components: {
            "组件名(不能用驼峰命名)": {
                template: "html模板字符串",

                //data为什么是个函数(仔细思考!!!)
                data(){
                    return {
                        // 这里就是数据
                    }
                }
            }
        }
    })


    var obj = Vue.extend({
        template: "html模板字符串",
        data(){
            return {
                // 这里就是数据
            }
        }
    })

    Vue.component("组件名", obj)

如何在页面中使用一个组件

<组件名></组件名>

<组件名/>

预习组件!

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,654评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,107评论 25 707
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,050评论 0 29
  • 一念一世界,观念很重要(他想出一个策略。无论做什么事情,在开始之前,都要想尽一切办法为这个事情赋予重大的意义,甚至...
    lushunneng阅读 291评论 0 0
  • 很多时候,我们会经常忽视我们身边的亲人,无论工作多忙,都应该多陪陪他们,每个人的生命只有一次,如果选择错了,可能会...
    秋刀鱼的幻想阅读 375评论 0 0