vue-cli3構建ts項目

来源:https://www.cnblogs.com/gxp69/archive/2019/08/06/11302095.html
-Advertisement-
Play Games

1、構建項目 上面的第一條,也就是 aaa 這一個選項在你第一次創建項目的時候是並不會出現的,只有你第一次創建完成項目後回提示你保存為預設配置模板,下次新建項目的時候就可以使用你選用的配置快速新建項目了,不需要再重新選擇配置項目了。 第二條選項便是 vue cli 3 預設的項目模板,包含 babe ...


1、構建項目

vue create xxx

上面的第一條,也就是 aaa 這一個選項在你第一次創建項目的時候是並不會出現的,只有你第一次創建完成項目後回提示你保存為預設配置模板,下次新建項目的時候就可以使用你選用的配置快速新建項目了,不需要再重新選擇配置項目了。

第二條選項便是 vue cli 3 預設的項目模板,包含 babel 和 eslint。

第三條選項便是自主選擇你項目所需的配置。

這裡由於預設模板沒有啥展示的必要所以我們便選擇手動配置。

選擇項目配置:

這裡我們可以選擇我們需要的配置選項,選擇完成後回車進入下一步。

在選擇功能後,會詢問更細節的配置

 

TypeScript:

  1. 是否使用class風格的組件語法:Use class-style component syntax?

  2. 是否使用babel做轉義:Use Babel alongside TypeScript for auto-detected polyfills?

Router:

  1.是否使用history模式:Use history mode for router?

CSS Pre-processors:

  1. 選擇CSS 預處理類型:Pick a CSS pre-processor

Linter / Formatter

  1. 選擇Linter / Formatter規範類型:Pick a linter / formatter config

  2. 選擇lint方式,保存時檢查/提交時檢查:Pick additional lint features

Testing

  1. 選擇Unit測試方式

  2. 選擇E2E測試方式

選擇 Babel, PostCSS, ESLint 等自定義配置的存放位置 Where do you prefer placing config for Babel, PostCSS, ESLint, etc.?

 

創建成功。

2、修改配置

 vue-cli3腳手架生成項目目錄說明

│  .browserslistrc
│  .gitignore
│  .postcssrc.js // postcss 配置
│  babel.config.js
│  package.json // 依賴
│  README.md // 項目 readme
│  tsconfig.json // ts 配置
│  tslint.json // tslint 配置
│  vue.config.js // webpack 配置(~自己新建~)
│  yarn.lock
│  
├─public // 靜態頁面
│  │—favicon.ico
│  │—index.html
│ 
├─src // 主目錄
│  ├─assets // 靜態資源
│  │      logo.png
│  │  
│  ├─components
│  │      HelloWorld.vue
│  │ 
│  │─views // 頁面
│  │      About.vue
│  │      Home.vue
│  │ 
│  │  App.vue // 頁面主入口
│  │ 
│  │  main.ts // 腳本主入口
│  │ 
│  ├─router // 路由配置
│  │      index.ts
│  │  
│  │  registerServiceWorker.ts // PWA 配置
│  │ 
│  │  shims-tsx.d.ts
│  │  shims-vue.d.ts
│  │         
│  │  
│  ├─store // vuex 配置
│  │      index.ts
│  │      
│  ├─typings // 全局註入(~自己新建~)
│  │  
│  ├─utils // 工具方法(axios封裝,全局方法等)(~自己新建~)
│  
│          
└─tests // 測試用例
    ├─e2e
    │  ├─plugins
    │  │      index.js
    │  │      
    │  ├─specs
    │  │      test.js
    │  │      
    │  └─support
    │          commands.js
    │          index.js
    │          
    └─unit
            HelloWorld.spec.ts        

1、在.browserslistrc文件中添加

last 3 ie versions,
not ie <= 8

其它配置,請去https://github.com/browserslist/browserslist。npx browserslist在項目目錄中運行以查看查詢選擇了哪些瀏覽器

2、tslint配置

// 關閉console
"no-console": [true, "log", "dir", "table"]
    
// tslint的函數前後空格:
"space-before-function-paren": ["error", {
  "anonymous": "always",
  "named": "always",
  "asyncArrow": "always"
}]


// tslint分號的配置:
"semicolon": [true, "never"]

其它規則:https://palantir.github.io/tslint/rules/

3、路由處理邏輯(登錄驗證、攔截等)

// main.ts文件

router.beforeEach((to: any, from: any, next: any) => {
  if (to.name === 'login') {
    next({name: 'home/index'})
  } else {
    next()
  }
})

4、axios改造

npm i axios --save

src下新建axios.d.ts axios.config.ts文件

//axios.config.ts
import axios, { AxiosInstance } from 'axios' declare module 'Vue/types/vue' { interface Vue { $axios: AxiosInstance } }
// main.ts文件
import Vue from 'vue';
import axios from 'axios';

Vue.prototype.$axios = axios;

/**
* 創建 axios 實例
*/
const service = axios.create({
timeout: 3000,
baseURL: 'http://xxx',
});

/**
* req 攔截器
*/
service.interceptors.request.use((config: object): object => {
return config
}, (error: any): object => {
return Promise.reject(error)
});

/**
* res 攔截器
*/
service.interceptors.response.use((response: any) => {
const res = response.data;
if (res.error) {
if (process.env.NODE_ENV !== 'production') {
console.error(res);
}
return Promise.reject(res);
}
return Promise.resolve(res);
});
// main.ts
import './axios.config';

4、store改造

├── index.html
├── main.js
├── components
│   ├── App.vue
│   └── ...
└── store
    ├── index.ts          # 我們組裝模塊並導出 store 的地方
    ├── actions.ts        # 根級別的 action
    ├── mutations.ts      # 根級別的 mutation
    └── modules
        ├── cart.ts      # 購物車模塊

 

使用:

  • 使用module形式
  • 全局的一些操作,方法,放入store中,業務邏輯儘量少放,項目全局方法可以放入。例如:cookieglobal cache

  action(非同步): api的操作, 調用方式:this.$store.dispatch(functionName, data)

  mutations(同步): dom相關操作,方法名一般使用常量,
  調用方式: this.$store.commit(mutationsName, data)

  this.$store.getters[XXX] => this.$store.getters[namespaced/XXX]
  this.$store.dispatch(XXX, {}) => this.$store.dispatch(namespaced/XXX, {})
  this.$store.commit(XXX, {}) => this.$store.commit(namespaced/XXX, {})
//store/index.ts
import Vue from 'vue';
import Vuex from 'vuex';
import cart from './modules/cart';

Vue.use(Vuex);

export default new Vuex.Store({
  modules: {
    cart,
  },
});
// cart.ts
import {ActionContext} from 'vuex';
export interface State {
    token: string;
}

const state: State = {
    token: '',
};

// getters
const getters = {
    toUpperToken: (state: State) => {
        return state.token.toUpperCase();
    },
};

// actions
const actions = {
    setTokenAsync({ commit }: ActionContext<State, State>, payload: any) {
        setTimeout(() => {
            commit('setToken', payload);
        }, 1000);
    },
};

// mutations
const mutations = {
    setToken(state: State, payload: any) {
        state.token = payload;
    },
};

export default {
    namespaced: true,
    state,
    getters,
    actions,
    mutations,
};

5、vue.config.js配置

  https://cli.vuejs.org/zh/config/#vue-config-js所列出的屬性,可以直接配置。其它屬性可以通過configureWebpackchainWebpack配置。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 可以在main.js中寫入方法 HTML部分 需要將v-model拆分為:value和@input 通過以上方法又擴展出以下方法 ...
  • call,apply,bind均是用於改變this指向。 三者相似之處: 1:都是用於改變函數的this指向。 2:第一個參數都是this要指向的對象。 3:都可以通過後面的參數進行對方法的傳參。 在圖中可以看到只有age是有值的,直接調用fn方法,this預設指向為window。 address因 ...
  • 效果圖,用的faststone--錄像--togif,黃色圓圈實際是不顯示的 博客後臺管理設置 本地新建一個demo.html文件,可以自行測試,要引入jquery文件哦 來個“紅橙黃綠藍靛紫”的點擊特效 <!DOCTYPE html> <html> <head> <meta charset="UT ...
  • html 結構 script部分 ...
  • 數據結構: 需求:我在vue頁面需要拿到url值並顯示圖片 代碼寫法: 註意:一定要判斷否則拿到的large對象一直是空值, 那麼img.large.url將會取不到值,會報 url 'undefined'錯誤的 ...
  • 1. filter針對數組起過濾作用篩選出符合條件的一個或多個元素 lvar newarr = [ { num: 1, val: 'ceshi', flag: 'aa' }, { num: 2, val: 'ww' } ] console.log(newarr.filter(item => item ...
  • 1. typeof 運算符 typeof 可以判斷基本數據類型: typeof 123; // "number" typeof 'abc'; // "string" typeof true; // "boolean" 碰到複合數據類型的情況: typeof {}; // "object" typeo ...
  • 1.1什麼是函數提升和變數的提升? JS引擎在運行整個JS代碼的過程中,分為倆步。 第一步是讀取和解析JS代碼,第二部是執行。 在引擎解析JS代碼的時候,當解析器遇見變數聲明(var 變數名)和函數聲明 (function 函數名)的時候,會將這些聲明提到各自作用域的最前面。 1.2 作用域 在ES ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...