Vue05

Vue05

  • 一个重要的内置关系:VueComponent.prototype.__ proto ____===Vue.prototyoe

  • 为什么要有这个关系:让组件实例对象(vc)可以访问到Vue原型上的属性和方法

单文件组件

注:cli的全称 command line interface

一般叫做:脚手架

具体步骤

  1. 全局安装@vue/cli

  2. npm install -g @vue/cli

  3. 切换到你要创建项目的目录,然后使用命令创建项目

  4. vue create xxx

  5. 启动项目

  6. npm run serve

分析脚手架结构

  • babel.config.js

    • 把es6 转换成 es5
  • package-lock.json

    • 包版本控制文件
  • package.json

    • 配置名,版本,依赖

    • 常用的命令

      • serve

      • build (最后的一次编译)

      • lint (语法检查)

  • main.js

    • npm run serve 执行后,直接去执行main.js
  • assets文件夹

    • 放静态资源
  • index.html

    // 针对IE浏览器的一个特殊配置,含义是让IE浏览器以最高的渲染级别渲染页面

    //开启移动端的理想视口

    //配置页面图标

    //配置网页的标题
    <%= htmlWebpackPlugin.options.title %>

render函数

  1. vue.js与vue.runtime.xxx.js的区别

  2. vue.js是完整版的Vue,包含:核心功能+模板解析器

  3. vue.runtime.xx.js 是运行版的eVue,只包含:核心功能,没有模板解析器

  4. 因为vue.runtime.xxx.js没有模板解析器,所以不能使用template配置项,需要使用render函数接受到的createElement函数去指定具体内容

    render:h => h(App),

    //完整的写法如下

    render(createElement){

    return createElement('h1','你好啊')

    }

    //注:h 是 createElement ,前面是传入一个实例(需要在main.js里面引入),后面的参数,第一个是标签,第二个是标签内容

ref属性

  • 被用来给元素或子组件注册引用对象(id的替代者)

  • 应用在html标签上获取的是真实DOM元素,应用在组件标签上是组件实例对象

  • 使用方式

    • 打标识

    • <h1 ref="xxx">...

    • <School ref="xxx"/>

    • 获取

    • this.$refs (获取全部)

    • this.$refs.xxx

props配置项

复制代码
//功能:让组件接收外部传过来的数据

//传递数据
<Demo name="xxx">


//接收数据

//只接收
props:['name']

//限制类型
props:{
    name:String
}

//限制类型,限制必要性,指定默认值
props:{
    name:{
        type:String,
        required:true,
        default:'老王'
    }
}


//备注:props是只读的,Vue底层回监测对props的修改,如果进行了修改,就会发出警告,若业务需求确实需要修改,那么复制props的内容到data中一份,然后去修改data中的数据

mixins配置项(混入)

功能:可以把多个组件共用的配置提取成一个混入对象

使用方式: //第一步定义混合 //在一个单独的js文件中定义 { data(){...}, methods:{...}, ... } //第二步使用混入,例如 //全局混入 Vue.mixin(xxx) //局部混入 mixins:'xxx'

插件(plugins)

功能:用于增强Vue

本质:包含install 方法的一个对象,install的第一个参数是Vue,第二个以后的参数是缔造者传递的数据 //定义插件,写在一个js文件中 对象.install = function(Vue,options){ //添加全局过滤器 Vue.filter(...) //添加全局指令 Vue.directive(...) //配置全局混入 Vue.mixin(...) //添加实例方法 Vue.prototype.$myMethod = function(){...} } //使用插件,在main.js import xxx from './plugins' Vue.use(xxx)

scoped样式

在style标签里面,添加该属性,防止组件之间的属性重名,导致样式被覆盖

组件的自定义事件

  • 一种组件间通信的方式,适用于:子组件 ==> 父组件

  • 注:a 是父组件,b 是子组件。b想给a传数据,那么就要在a中给b绑定自定义事件(事件的回调在a中)

  • 绑定自定义事件

    • 在父组件中:<Demp @xxx="xxx">或<Demp v-on:xxx="xxx">

    • 在父组件中<Demo ref="demo"/>,在其mounted钩子中写mounted(){ this.refs.xxx.on('xxxx',this.fuanc)

    • 若想让自定义事件只能触发椅子,可以使用once修饰符或 $once方法

  • 触发自定义事件:this.$emit('xxxx',数据)

  • 解绑自定义事件: this.$off('xxxx')

  • 组件上也可以绑定原生DOM事件,需要使用native修饰符

  • 注意:通过this.reds.xxx.on('xxxx',回调),回调要吗配置在methods中,要么用箭头函数,否则this指向回出问题

全局事件总线

  1. 一种组件间通信的方式,适用于任意组件间通信

  2. 安装全局事件总线

  3. 使用事件总线

  4. 最好在beforeDestroy钩子中,用$off去解绑当前组件所用到的事件

javascript 复制代码
    //安装全局事件总线
    
    new Vue({
        beforeCreate(){
            Vue.prototype.$bus = this
            //安装全局事件总线,$bus就是当前应用的vm
        }
    })
    
    
    
    //使用事件总线
    //1,接收数据:A组件想接收数据,则在A组件中给$bus绑定事件,事件的回调留在A组件自身
    
    
    methods(){
        demo(data){...}
    }
    ...
    mounted(){
        this.$bus.$on('xxx',this.demo)
    }
    
    
    //2,提供数据
    
    
    this.$bus.$emit('xxx',数据)

消息订阅与发布

npm i pubsub-js 安装这个库

javascript 复制代码
1. 一种组件间通信的方式,适用于任意组件间通信
  
2. 使用步骤 //1 安装pubsub //2 引入 import pubsub from 'pubsub-js' //3 接收数据:a组件想接收数据,则在a组件中订阅消息,订阅的回调留在a组件自身
  

    methods(){
        demo(data){...}
    }
    ...
    mounted(){
        this.pid = pubsub.subscribe('xxx,this.demo')//订阅消息
    }
    
    
    //4 提供数据:pubsub.publish('xxx',数据)
    
    
    //5 最好在beforeDestroy钩子中,用PubSub.unsubsceibe(pid) 去取消订阅

nextTick

  1. 语法: this.$nextTick(回调函数)

  2. 作用:在下一次DOM更新结束后执行其指定的回调

  3. 什么是用:当改变数据后,要基于更新后的新DOM进行某些操作时,要在nextTick所指定的回调函数中执行

相关推荐
swipe5 小时前
DeepAgents 实战:用多 Agent 架构搭一个深度调研助手
javascript·面试·llm
云水一下7 小时前
JavaScript 从零基础到精通系列:前世今生与编程启蒙
前端·javascript
月亮邮递员6167 小时前
Markdown语法总结
开发语言·前端·javascript
丷丩8 小时前
MapLibre GL JS第27课:添加COG栅格源
javascript·map·mapbox·maplibre gl js
不好听61310 小时前
JavaScript 到底是怎么运行的?从编译阶段到执行上下文全面解析
javascript
丷丩10 小时前
MapLibre GL JS第29课:添加Canvas源
javascript·gis·map·mapbox·maplibre gl js
utf8mb4安全女神10 小时前
【rsyslog服务】把所有服务的“临界点”以上的错误都保存在/var/log/alert.log⽇志中
java·前端·javascript
csdn_aspnet10 小时前
javascript 算法 LeetCode 编号 70 - 爬楼梯
开发语言·javascript·算法·leetcode·ecmascript
swipe10 小时前
DeepAgents 多 Agent 深度调研助手工程实战:从 createDeepAgent 到可控调研工作流
javascript·面试·langchain
moMo11 小时前
JavaScript 变量提升,执行上下文里的各种门道
javascript·面试