pinia使用 技术(vue3+ts)

当你需要在子页面的请求数据中的长度进传给父亲,我们可以使用pinia(菠萝)

1.下载

npm install pinia
或者
yarn add pinia

2.在 main.ts 中引入

3.创建文件

         src > store > 自定名.ts

4.定义数据

import { defineStore } from "pinia"

// 1.定义并导出
// 参数1:容器的 ID,必须唯一,将来 Pinia 会把所有的容器挂载到跟容器
export const useMainStore = defineStore('main', {
  /**
   * 类似于组件的 data,用来存储全局状态
   */
  state: () => {
    return {
        //定义的数据
        dataA:0,
    }
  },

  /**
   * 类似组件的  computed,用来封装计算属性,有缓存功能
   */
  getters: {

  },
  
  /**
   * 类似组件的 methods,封装业务逻辑,修改 state
   */
  actions: {
    //在子页面获取的val
    setData(value:number) {
        //进行赋值操作,获取最新的值
        this.dataA = value;
      },
  },
})

 5.子页面传数据给pinia

<script setup lang="ts">
//导入进来
import { useMainStore } from '../../../store/quantity.ts';
const childStore = useMainStore();


const init = () => {
  const data = {
    "usedb": "test",
    "userid": idA.value,
    "type": "1"
  };
  post("/api/task/orderlist", data).then((res: any) => {
    console.log(res.data.Data);
    list.value = res.data.Data;
    //获取所需的值   在这个地方写进去了,就相当于传给了pinia的value
    childStore.setData(list.value.length);
  });
};
</script>

6.在父页面进行使用


<script setup lang="ts">
//引入
import { useMainStore } from '../../store/quantity.ts';
const childStore = useMainStore();

//在这里输出一下,大部分输出的是默认值,0,而不是最新值,但是在页面输出是最新值,
//因为我们拿到的不是最新的值
console.log(childStore.dataA);

//如果直接使用在页面上就不用做以下操作,如果拿值有用的话,使用下面获取最新的值
watch(() =>childStore.dataA,(newValue: any,losvuele) => {
      console.log(newValue,losvuele);
        newValue最新的值,可进行你所需的操作
  }
);

</script>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于使用 Vite + Vue3 + TypeScript + Pinia + Vue Router + Axios + SCSS 并自动导入 API 的设置,你可以按照以下步骤进行操作: 1. 首先,确保你已经安装了 Node.js,并且版本大于等于 12.0.0。 2. 创建一个新的 Vue 项目,可以使用 Vue CLI 或者手动创建一个空文件夹。 3. 在项目根目录下,打开终端并执行以下命令安装 Vite: ```bash npm init vite@latest ``` 按照提示选择你的项目配置,包括选择 Vue 3、TypeScript 和其他选项。 4. 进入项目目录并安装依赖: ```bash cd your-project-name npm install ``` 5. 安装 Pinia 插件: ```bash npm install pinia ``` 6. 创建一个 `src/store` 目录,并在其中创建 `index.ts` 文件,用于定义和导出你的 Pinia store。 ```typescript // src/store/index.ts import { createPinia } from 'pinia' export const store = createPinia() // 可以在这里定义你的 store 模块 ``` 7. 在项目根目录下创建 `src/api` 目录,用于存放 API 请求相关的文件。 8. 在 `src/api` 目录下创建一个 `index.ts` 文件,用于自动导入所有 API 文件。 ```typescript // src/api/index.ts const modules = import.meta.globEager('./*.ts') const apis: any = {} for (const path in modules) { if (path !== './index.ts') { const moduleName = path.replace(/^.\/|\.ts$/g, '') apis[moduleName] = modules[path].default } } export default apis ``` 这样,你就可以在 `src/api` 目录下创建各种 API 请求的文件,例如 `user.ts`: ```typescript // src/api/user.ts import axios from 'axios' export function getUser(id: number) { return axios.get(`/api/user/${id}`) } ``` 然后,在你的组件中使用自动导入的 API: ```typescript import { defineComponent, ref } from 'vue' import { useUserStore } from '@/store' import apis from '@/api' export default defineComponent({ setup() { const userStore = useUserStore() const userId = ref(1) const fetchUser = async () => { const response = await apis.user.getUser(userId.value) userStore.setUser(response.data) } return { userId, fetchUser, } }, }) ``` 以上就是使用 Vite + Vue3 + TypeScript + Pinia + Vue Router + Axios + SCSS 并自动导入 API 的基本设置。你可以根据自己的需求进一步配置和扩展。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值