欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在vue中使用ts的示例代碼

 更新時間:2018年02月28日 10:52:47   作者:羅學(xué)  
本篇文章主要介紹了如何在vue中使用ts的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

本文介紹了如何在vue中使用ts的示例代碼,分享給大家,具體如下:

注意:此文并不是把vue改為全部替換為ts,而是可以在原來的項目中植入ts文件,目前只是實踐階段,向ts轉(zhuǎn)化過程中的過渡。

ts有什么用?

類型檢查、直接編譯到原生js、引入新的語法糖

為什么用ts?

TypeScript的設(shè)計目的應(yīng)該是解決JavaScript的“痛點”:弱類型和沒有命名空間,導(dǎo)致很難模塊化,不適合開發(fā)大型程序。另外它還提供了一些語法糖來幫助大家更方便地實踐面向?qū)ο蟮木幊獭?br />

typescript不僅可以約束我們的編碼習(xí)慣,還能起到注釋的作用,當(dāng)我們看到一函數(shù)后我們立馬就能知道這個函數(shù)的用法,需要傳什么值,返回值是什么類型一目了然,對大型項目的維護性有很大的提升。也不至于使開發(fā)者搬起石頭砸自己的腳。

Angular: 我們?yōu)槭裁催x擇TypeScript?

  1. TypeScript 里優(yōu)秀的工具
  2. TypeScript 是 JavaScript 的超集
  3. TypeScript 使得抽象清晰可見
  4. TypeScript 使代碼更容易閱讀和理解

是的,我知道這看起來并不直觀。讓我用一個例子來說明我的意思。讓我們來看看這個函數(shù)jQuery.ajax()。我們能從它的簽名中得到什么信息?

我們唯一能確定的是這個函數(shù)有兩個參數(shù)。我們可以猜測這些類型。也許第一個是字符串,第二個是配置對象。但這只是猜測,我們可能錯了。我們不知道什么選項進入設(shè)置對象(它們的名稱和類型),或者該函數(shù)返回什么。

在不檢查源代碼或文檔的情況下,我們不可能調(diào)用這個函數(shù)。檢查源代碼并不是一個好的選擇——擁有函數(shù)和類的目的,是在不知道如何實現(xiàn)它們的情況下使用它們。換句話說,我們應(yīng)該依賴于他們的接口,而不是他們的實現(xiàn)。我們可以檢查文檔,但這并不是最好的開發(fā)經(jīng)驗——它需要額外的時間,而且文檔經(jīng)常過期。

因此,盡管很容易閱讀jQuery.ajax(url,settings),真正理解如何調(diào)用這個函數(shù),我們需要閱讀它的實現(xiàn)或它的文檔。

以下是一個類型版本:

它給了我們更多的信息。

  1. 這個函數(shù)的第一個參數(shù)是一個字符串。
  2. 設(shè)置參數(shù)是可選的。我們可以看到所有可以傳遞到函數(shù)中的選項,不僅是它們的名稱,還包括它們的類型。
  3. 函數(shù)返回一個JQueryXHR對象,我們可以看到它的屬性和函數(shù)。

類型化簽名肯定比未類型化的簽名長,但是:string,:JQueryAjaxSettings和JQueryXHR并不是混亂的。 它們是提高代碼的可理解性的重要文檔。我們可以更深入地理解代碼,而不必深入到實現(xiàn)或讀取文檔中。 我的個人經(jīng)驗是,我可以更快地閱讀類型化代碼,因為類型提供了更多的上下文來理解代碼。

摘自 Angular: 我們?yōu)槭裁催x擇TypeScript?

ts好學(xué)嗎?

TypeScript的一個設(shè)計亮點就是它并沒有拋棄JavaScript的語法另起爐灶,而是做成了JavaScript的超集(這個功勞應(yīng)該記在Anders上),這樣任何合法的JavaScript的語句在TypeScript下都是合法的,也就是說學(xué)習(xí)成本很低,如果你對JavaScript有比較深入的了解,那么其實可以很快的上手TypeScript,因為它的設(shè)計都是針對JavaScript的使用習(xí)慣和慣例。
一些簡單的例子,一看即懂:

基礎(chǔ)類型

let isDone: boolean = false; // 布爾值
let decLiteral: number = 6;  // 數(shù)字
let name: string = "bob"; // 字符串
let list: number[] = [1, 2, 3]; // 數(shù)組
...
...

接口

function printLabel(labelledObj: { label: string }) {  console.log(labelledObj.label);
 } let myObj = { size: 10, label: "Size 10 Object" };
 printLabel(myObj);

類型檢查器會查看printLabel的調(diào)用。 printLabel有一個參數(shù),并要求這個對象參數(shù)有一個名為label類型為string的屬性。 需要注意的是,我們傳入的對象參數(shù)實際上會包含很多屬性,但是編譯器只會檢查那些必需的屬性是否存在,并且其類型是否匹配。

當(dāng)然還有一些高級的用法,這里就不做過多的介紹了,了解更多

如何在vue項目中應(yīng)用ts?

1、首先安裝ts

npm install --save-dev typescript npm install --save-dev ts-loader

2、在根目錄建tsconfig.json文件

{
  "compilerOptions": {
   "experimentalDecorators": true,
   "emitDecoratorMetadata": true,
   "lib": ["dom","es2016"],
   "target": "es5"
  },
  "include": ["./src/**/*"] }

3、在配置中添加 ts-loader

{
  test: /\.tsx?$/,
  loader: 'ts-loader',  exclude: /node_modules/,   options: {
   appendTsSuffixTo: [/\.vue$/],
  }
 }

4、最后把 .ts 后綴添加上就OK了,在webpack.base.conf.js文件下

現(xiàn)在就可以在我們原本的項目中使用ts文件了。

如何實踐?

1、如何在js中引用ts文件?

由于js文件沒有類型檢測,當(dāng)我們把ts文件引入的時候,ts文件會轉(zhuǎn)化成js文件,所以在js文件中引用ts文件的方法類型檢測機制不會生效。也就是說只有在ts文件內(nèi)才會有類型檢測機制。

那么怎么在js文件中使用類型檢測機制呢?小編自己封裝了一套typeCheck的decorator方法,僅供參考!用法如下:

@typeCheck('object','number') deleteItem(item,index) {}

檢測deleteItem方法參數(shù): item為object類型,index為number類型,如果類型不匹配將會拋出異常

部分代碼獻上:

const _check = function (checked,checker) {
    check:      for(let i = 0; i < checked.length; i++) {       if(/(any)/ig.test(checker[i]))          continue check;       if(_isPlainObject(checked[i]) && /(object)/ig.test(checker[i]))      continue check;       if(_isRegExp(checked[i]) && /(regexp)/ig.test(checker[i]))      continue check;       if(Array.isArray(checked[i]) && /(array)/ig.test(checker[i]))      continue check;       let type = typeof checked[i];       let checkReg = new RegExp(type,'ig')       if(!checkReg.test(checker[i])) {          console.error(checked[i] + 'is not a ' + checker[i]);          return false;
   }
  }  return true;
 } /**
  * @description 檢測類型
  *  1.用于校檢函數(shù)參數(shù)的類型,如果類型錯誤,會打印錯誤并不再執(zhí)行該函數(shù);
  *  2.類型檢測忽略大小寫,如string和String都可以識別為字符串類型;
  *  3.增加any類型,表示任何類型均可檢測通過;
  *  4.可檢測多個類型,如 "number array",兩者均可檢測通過。正則檢測忽略連接符 ;
  */
 export function typeCheck() {     const checker = Array.prototype.slice.apply(arguments);       return function (target, funcName, descriptor) {          let oriFunc = descriptor.value;
       descriptor.value = function () {           let checked = Array.prototype.slice.apply(arguments);             let result = undefined;             if(_check(checked,checker) ){
           result = oriFunc.call(this,...arguments);
    }       return result;
   }
  }
 };

ts的類型檢測配合typeCheck基本上已經(jīng)滿足了我們的需要。

2、如何在ts中引用js文件?

由于js文件中沒有類型檢測,所以ts文件引入js文件時會轉(zhuǎn)化為any類型,當(dāng)然我們也可以在 .d.ts文件中聲明類型。

如 global.d.ts 文件

當(dāng)然有的時候我們需要使用一些庫,然而并沒有聲明文件,那么我們在ts文件中引用的時候就會是undefined。這個時候我們應(yīng)該怎么做?

比如我想要在util.ts文件中用 ‘query-string'的時候我們就會這樣引用:

import querystring from 'query-string';

然而當(dāng)你打印querystring 的時候是undefined。如何解決呢?小編的方法也僅供參考

新建module.js文件

import querystring from 'query-string'; export const qs = querystring;

utile.ts 文件

import { qs } from './module.js';

解決了。打印qs不再是undefined,可以正常使用qs庫了哦。

至此本文就將ts在vue中的配置介紹結(jié)束,此文只代表個人看法,考慮到項目的擴展性,所以沒有全部替換成ts,只是嘗試性在vue中引入ts,還有很多需要改進的地方,如果有更好的建議和意見可以聯(lián)系我!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 簡單談一談Vue中render函數(shù)

    簡單談一談Vue中render函數(shù)

    vue中的render函數(shù),它返回的是一個虛擬節(jié)點vnode,也就是我們要渲染的節(jié)點,下面這篇文章主要給大家介紹了關(guān)于Vue中render函數(shù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • Vue內(nèi)容分發(fā)slot(全面解析)

    Vue內(nèi)容分發(fā)slot(全面解析)

    下面小編就為大家?guī)硪黄猇ue內(nèi)容分發(fā)slot(全面解析)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • vue中的事件修飾符介紹和示例

    vue中的事件修飾符介紹和示例

    在Vue中,修飾符處理了許多DOM事件的細節(jié),讓我們不再需要花大量的時間去處理這些煩惱的事情,而能有更多的精力專注于程序的邏輯處理,需要的朋友可以參考下
    2023-04-04
  • vue實現(xiàn)虛擬滾動的示例詳解

    vue實現(xiàn)虛擬滾動的示例詳解

    虛擬滾動或者移動是指禁止原生滾動,之后通過監(jiān)聽瀏覽器的相關(guān)事件實現(xiàn)模擬滾動,下面小編就來和大家詳細介紹一下vue實現(xiàn)虛擬滾動的示例代碼,需要的可以參考下
    2023-10-10
  • vue單頁應(yīng)用加百度統(tǒng)計代碼(親測有效)

    vue單頁應(yīng)用加百度統(tǒng)計代碼(親測有效)

    這篇文章主要介紹了vue單頁應(yīng)用加百度統(tǒng)計代碼的解決方法,需要的朋友參考下吧
    2018-01-01
  • vue2.0 如何把子組件的數(shù)據(jù)傳給父組件(推薦)

    vue2.0 如何把子組件的數(shù)據(jù)傳給父組件(推薦)

    這篇文章主要介紹了vue2.0 如何把子組件的數(shù)據(jù)傳給父組件,需要的朋友可以參考下
    2018-01-01
  • vue proxyTable的跨域中pathRewrite配置方式

    vue proxyTable的跨域中pathRewrite配置方式

    這篇文章主要介紹了vue proxyTable的跨域中pathRewrite配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue3?+?async-validator實現(xiàn)表單驗證的示例代碼

    vue3?+?async-validator實現(xiàn)表單驗證的示例代碼

    表單驗證可以有效的過濾不合格的數(shù)據(jù),減少服務(wù)器的開銷,并提升用戶的使用體驗,今天我們使用?vue3?來做一個表單驗證的例子,需要的朋友跟隨小編一起學(xué)習(xí)下吧
    2022-06-06
  • Vue自定義實現(xiàn)一個消息通知組件

    Vue自定義實現(xiàn)一個消息通知組件

    這篇文章主要為大家詳細介紹了如何利用Vue自定義實現(xiàn)一個消息通知組件,文中的示例代碼講解詳細,具有一定的借鑒價值,有需要的小伙伴可以參考下
    2024-03-03
  • Vue循環(huán)遍歷選項賦值到對應(yīng)控件的實現(xiàn)方法

    Vue循環(huán)遍歷選項賦值到對應(yīng)控件的實現(xiàn)方法

    這篇文章主要介紹了Vue-循環(huán)遍歷選項賦值到對應(yīng)控件的實現(xiàn)方法啊,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06

最新評論