完整的 Vue 2 + TypeScript + Vuex 的项目案例

下面是一个完整的 Vue 2 + TypeScript + Vuex 的项目案例。这个示例包括了基本的项目结构、Vuex 模块、组件和路由配置。

项目结构

src/

├── assets/

├── components/

│ └── Counter.vue

├── router/

│ └── index.ts

├── store/

│ ├── index.ts

│ └── modules/

│ └── counter.ts

├── App.vue

└── main.ts

  1. 安装依赖

首先确保安装了必要的依赖:

bash 复制代码
npm install vue vuex vue-router @types/node typescript ts-loader
  1. 配置 tsconfig.json

在项目根目录下创建 tsconfig.json 文件

javascript 复制代码
{
  "compilerOptions": {
    "target": "es5",
    "module": "esnext",
    "strict": true,
    "jsx": "preserve",
    "importHelpers": true,
    "moduleResolution": "node",
    "skipLibCheck": true,
    "esModuleInterop": true,
    "allowSyntheticDefaultImports": true,
    "sourceMap": true,
    "baseUrl": ".",
    "paths": {
      "@/*": ["src/*"]
    },
    "lib": ["esnext", "dom", "dom.iterable", "scripthost"]
  },
  "include": ["src/**/*.ts", "src/**/*.tsx", "src/**/*.vue"],
  "exclude": ["node_modules"]
}
  1. 配置 main.ts

在 src/main.ts 中配置 Vue 应用:

TypeScript 复制代码
import Vue from 'vue';
import App from './App.vue';
import router from './router';
import store from './store';

Vue.config.productionTip = false;

new Vue({
  router,
  store,
  render: h => h(App),
}).$mount('#app');
  1. 配置 Vuex 存储

在 src/store/index.ts 中配置 Vuex 存储:

TypeScript 复制代码
import Vue from 'vue';
import Vuex from 'vuex';
import counter from './modules/counter';

Vue.use(Vuex);

export default new Vuex.Store({
  modules: {
    counter,
  },
});

在 src/store/modules/counter.ts 中定义 counter 模块:

TypeScript 复制代码
import { Module, ActionContext } from 'vuex';

interface State {
  count: number;
}

const counter: Module<State, any> = {
  state: (): State => ({
    count: 0,
  }),
  mutations: {
    increment(state: State) {
      state.count++;
      console.log('increment:', state.count);
    },
  },
  getters: {
    doubleCount: (state: State) => state.count * 2,
  },
  actions: {
    asyncIncrement({ commit }: ActionContext<State, any>) {
      setTimeout(() => {
        commit('increment');
      }, 1000);
    },
  },
};

export default counter;
  1. 配置路由

在 src/router/index.ts 中配置路由:

TypeScript 复制代码
import Vue from 'vue';
import VueRouter from 'vue-router';
import Counter from '../components/Counter.vue';

Vue.use(VueRouter);

const routes = [
  {
    path: '/',
    name: 'Counter',
    component: Counter,
  },
];

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes,
});

export default router;
  1. 创建组件

在 src/components/Counter.vue 中创建 Counter 组件:

TypeScript 复制代码
<template>
  <div>
    <h1>Counter</h1>
    <p>Count: {{ count }}</p>
    <p>Double Count: {{ doubleCount }}</p>
    <button @click="increment">Increment</button>
    <button @click="asyncIncrement">Async Increment</button>
  </div>
</template>

<script lang="ts">
import { Component, Vue } from 'vue-property-decorator';
import { mapState, mapGetters, mapActions } from 'vuex';

@Component({
  computed: {
    ...mapState(['count']),
    ...mapGetters(['doubleCount']),
  },
  methods: {
    ...mapActions(['increment', 'asyncIncrement']),
  },
})
export default class Counter extends Vue {}
</script>

<style scoped>
button {
  margin: 5px;
}
</style>
  1. 创建 App.vue

在 src/App.vue 中创建主应用组件:

TypeScript 复制代码
<template>
  <div id="app">
    <router-view />
  </div>
</template>

<script lang="ts">
import { Component, Vue } from 'vue-property-decorator';

@Component
export default class App extends Vue {}
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>
  1. 运行项目

最后,运行项目:

bash 复制代码
npm run serve

这个示例展示了如何在 Vue 2 项目中使用 TypeScript 和 Vuex。你可以根据需要扩展和修改这个基础结构。

相关推荐
崔庆才丨静觅8 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60619 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了9 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅9 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅9 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅10 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment10 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅10 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊10 小时前
jwt介绍
前端
爱敲代码的小鱼10 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax