• VUE -----组件传参


     🍓Vue.cli 中怎样使用自定义的组件?

    1. 第一步:在 components 目录新建你的组件文件( CounterCom.vue),script 一定要 export default {}
    2. 第二步:在需要用的页面(组件)中导入: import CounterCom from './components/CounterCom.vue'
    3. 第 三 步 : 注 入 到 Vue 的子组件的 components 属性上面,                                     components:{CounterCom}
    4. 第四步:在 template 视图 view 中使用                                                                                                                                                            

     

     🍓Vue 组件如何进行传值的?

    🐇 父组件向子组件传递数据

    父组件内设置要传的数据,在父组件中引用的子组件上绑定一个自定义属
    性并把数据绑定在自定义属性上,在子组件添加参数 props 接收即可

    🐇 子组件向父组件传递数据

    子组件通过 Vue 实例方法 $emit 进行触发并且可以携带参数,父组件监听使
    用@(v-on)进行监听,然后进行方法处理

    🐇 非父子组件之间传递数据

    1. 1、引入第三方 new Vue 定义为 eventBus
    2. 2、在组件中 created 中订阅方法 eventBus.$on("自定义事件名",methods 中的方法名)
    3. 3、在另一个兄弟组件中的 methods 中写函数,在函数中发布 eventBus 订 阅的方法     eventBus.$emit("自定义事件名”)
    4. 4、在组件的 template 中绑定事件(比如 click)

    🐇父传子例子

    使用props
    父传给子的数组是只读的(做默认值,读取显示)
    不能进行修改


        App.vue文件中

    <CounterCom :num="365">CounterCom>

    CounterCom.vue组件中
     

    1.   //01接收参数并定义默认值
    2. props:{
    3.     "num":{type:Number,default:1},
    4. }
    5. //02使用参数num
    6. data() {
    7.             //02 使用num:把传过来的num赋值给counter
    8.             return {
    9.                 counter: this.num
    10.             }
    11.         }

    具体示例如下:


     

     🐇子传父例子

    使用的事件  $emit


        CounterCom.vue组件中

    1. <button class="active" @click="counter++;$emit('counterchange',counter)">
    2.         {{counter}}
    3.     button>

       App.vue

    <counter-com @counterchange="n=$event">counter-com>

     $emit(事件名,事件值)  子组件主动触发一个事件,并传递一个位置,事件名(counterchange)和事件值(counter)是自定义的

    $event固定写法,事件的值(counterchange事件的值,也是数组的第二个参数)

     


     

     🍓Vue 组件 data 为什么必须是函数

    1. 1、每个组件都是 Vue 的实例。
    2. 2、组件共享 data 属性,当 data 的值是同一个引用类型的值时,改变 其中一个会影响其他
    3. 3、组件中的 data 写成一个函数,数据以函数返回值形式定义,这样每复用 一次组件,就会返回一份新的 data,类似于给每个组件实例创建一个私 有的数据空间,让各个组件实例维护各自的数据。而单纯的写成对象形式, 就使得所有组件实例共用了一份 data,就会造成一个变了全都会变的结 果。

     🍓组件的命名规范

    给组件命名有两种方式,
    一种是使用链式命名 my-component,
    一种是使用大驼峰命名 MyComponent,
    在 字 符 串 模 板 中
    都可以使用,
    在非字符串模板中最好使用,因为要遵循 W3C 规
    范中的自定义组件名 (字母全小写且必须包含一个连字符),避免和当前以及未
    来的 HTML 元素相冲突

     🍓Vue 组件里的定时器要怎么销毁?

    如果页面上有很多定时器,可以在 data 选项中创建一个对象 timer,
    每个定时器取个名字一一映射在对象 timer 中, 在 beforeDestroy 构造函数中
    for(let k in this.timer){clearInterval(k)};

    如果页面只有单个定时器,可以这么做。
    1. const timer = setInterval(() =>{}, 500);
    2. this.$once('hook:beforeDestroy', () => {
    3. clearInterval(timer);
    4. })

  • 相关阅读:
    torch.onnx.export详细介绍
    Vivado初体验LED工程
    Jmeter核心使用教程
    【SEO学习】其他技术
    Nmap使用技巧总结
    Google DataFlow入门与(Pub/Sub-DataFlow-BigQuery解决方案)
    R语言dplyr包select函数删除dataframe数据中的多个数据列(通过向量指定需要删除的数据列的集合、并且在向量的前面添加负号)
    SpringSecurity源码学习五:跨域与跨站请求伪造
    python3:len()返回对象的长度(元素数量) 2023-11-17
    使用Python爬取信息403解决,并统计汇总绘制直方图,柱状图,折线图
  • 原文地址:https://blog.csdn.net/weixin_45904557/article/details/126022740