码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vite+vue3 + ts 项目搭建——pinia


    内容拆分2
    之前写过vuex的文章,想用vuex的戳这:链接

    2. 状态管理:pinia
    1. 官网:链接

    2. 安装: npm install pinia

    3. 注册:

      //main.ts
      import { createApp } from 'vue'
      import './style.css'
      import App from './App.vue'
      import { pinia } from '/@/store'
      createApp(App)
      .use(pinia)
      .mount('#app')
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
    4. 配置:

      • 在src文件夹下创建store文件夹,创建index.ts作为入口,创建modules文件夹为模块文件,创建模块文件(layout.ts)
        在这里插入图片描述

        //store/index.ts
        import { createPinia } from "pinia";
        export const pinia = createPinia();
        
        • 1
        • 2
        • 3
        //store/modules/layout.ts
        import { defineStore } from 'pinia'
        import { ILayout, IUserInfo } from '/@/type/store/layout'
        
        export const useLayoutStore = defineStore({
            id: 'layout',
            state: ():ILayout => ({
                // 用户信息
                userInfo: {
                    name: '',
                    role: []
                },
            }),
            getters: {
                getUserInfo():IUserInfo {
                    return this.userInfo
                },
            },
            actions: {}
        })	
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
        • 9
        • 10
        • 11
        • 12
        • 13
        • 14
        • 15
        • 16
        • 17
        • 18
        • 19
        • 20
      • 定义参数类型信息接口:创建一个对应的src/type/store/layout.ts(一层层自己创建)来放置当前文件的
        在这里插入图片描述

         // 用户信息
         export interface IUserInfo {
           name: string,
           role: string[]
         }
         // state
         export interface ILayout {
           // 用户信息
           userInfo: IUserInfo
         }
        
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
        • 9
        • 10
        • 11

      5.使用:

      <script lang="ts">
      	import { defineComponent, ref } from 'vue'
      	import { useLayoutStore } from '/@/store/modules/layout'
      	export default defineComponent({
      	    name: 'Directive',
      	    setup() {
      	        const { getUserInfo } = useLayoutStore()
      	        const username = ref(getUserInfo.name)
      	        return {
      	            username,
      	        }
      	    }
      	})
      </script>
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14

    搞定,回去继续搭!

  • 相关阅读:
    CPS-8910
    分类预测 | Matlab实现GA-XGBoost遗传算法优化XGBoost的多特征分类预测
    感觉 C++ 很简单,但为何这么多劝退的?
    【MM32F5270开发板试用】浮点数学运算初体验
    etcd java 客户端jetcd库踩坑日志
    【知识整理】Git 使用实践问题整理
    04.在谷歌浏览器中安装模拟浏览器ChromeDriver的详细步骤
    为何我国会成为水稻进口大国?国稻种芯:很简单了---价格
    Elastic:推出 7.16.2 和 6.8.22 版本的 Elasticsearch 和 Logstash 以升级 Apache Log4j2
    行业报告 | 智慧三角:长三角掀起AI产业热潮
  • 原文地址:https://blog.csdn.net/weixin_46221198/article/details/127785557
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号