码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端学习笔记(4) Vue3 全局属性 app.config.globalProperties 使用案例


    Vue3 全局属性 app.config.globalProperties 使用案例

    • 1 前言
    • 2 app.config.globalProperties使用

    1 前言

    学习Vue3有个把月了,记录下学习中的小知识点。
    首先很多同学还没找到Vue3真正的官方文档,下面给出Vue3的文档网站
    Vue3官网文档
    Vue3API文档

    2 app.config.globalProperties使用

    官方解释:一个用于注册能够被应用内所有组件实例访问到的全局 property 的对象。

    案例:
    首先有一个请求后端接口的方法

    export function listByDictTypeCode(dictTypeCode: string): AxiosPromise<DictData[]> {
        return request({
            url: '/dict/data/dictTypeCode/' + dictTypeCode,
            method: 'get'
        });
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在main.ts文件中设置app.config.globalPropertie

    import {createApp} from 'vue'
    import ElementPlus from 'element-plus';
    import 'element-plus/dist/index.css'
    import App from './App.vue'
    import router from './router'
    import Pagination from '@/components/Pagination/index.vue';
    //引入请求接口的方法
    import { listByDictTypeCode } from '@/api/system/dictData';
    
    const app = createApp(App);
    
    //全局方法
    app.config.globalProperties.$listByDictTypeCode = listByDictTypeCode;
    
    app.component('Pagination', Pagination)
    app.use(router);
    app.use(ElementPlus);
    app.mount('#app');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    在Vue文件中使用getCurrentInstance(),通过proxy.$listByDictTypeCode就可以调用上面定义的方法

    这里省略了很多别的代码,只给了能够表明globalProperties使用的代码

    <template>
        <el-tree-select
              v-model="dataState.selectValue"
              :data="dataState.dictDataList"
              :props="defaultProps"
              check-strictly
              :render-after-expand="false"
          />
        </el-form-item>
    <template>
    
    <script setup lang="ts">
    import {nextTick, reactive, ref, getCurrentInstance} from "vue";
    const { proxy }: any = getCurrentInstance();
    
    const defaultProps = {
      label: 'name',
      value: 'id',
      children: 'children'
    }
    
    const dataState = reactive({
      selectValue: '',
      dictTypeCode: '',
      dictDataList: [] as DictData[]
    });
    
    function handleQuery() {
      proxy.$listByDictTypeCode(dataState.dictTypeCode).then((data: any) => {
        console.log(data.data)
        dataState.dictDataList = data.data;
      })
    }
    </script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    在这里插入图片描述

  • 相关阅读:
    【PCIE732】基于Kintex UltraScale系列FPGA的2路40G光纤通道适配器(5GByte/s带宽)
    Salesforce LWC学习(四十四) Datatable 显示日期类型的有趣点思考
    ECMAScript 6 入门 - 字符串的新增方法
    验证回文串问题带你轻松学会
    死锁是什么?死锁的字节码指令了解?
    自动驾驶感知算法实战3——自动驾驶2D和3D视觉感知算法概述
    ctfshow web入门(1)
    Oracle课程-深入学习文档
    个人前端编程技巧总结
    第3章:运行时数据区概述及线程 详细详解
  • 原文地址:https://blog.csdn.net/winterking3/article/details/126118712
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号