今回は Vue と Typescript の構築プロジェクトについて説明します。Vue と Typescript の構築プロジェクトの 注意事項 は何ですか? 実際のケースを見てみましょう。
Typescript はフロントエンド界隈で徐々に普及してきており、Vue 2.5.0 では型宣言が改良され、TypeScript にさらに親しみやすくなりました
ただし、プロジェクト内で TypeScript を直接使用したい場合は、引き続き次のことを行う必要があります。プロジェクトにいくつかの変更を加えました
PS: 開発にはVisual Studio Codeを使用することをお勧めします
1. 依存関係をインストールします
まず、vue-cliを使用してプロジェクトを生成します
vue init webpack demo
次に、必要な依存関係をインストールします: typescript、ts-loader、vue-class-component
npm install typescript vue-class-component -D
npm install ts-loader@3.3.1 -D
上記の ts-loader をインストールするときに、バージョン 3.3.1 が指定されました
これは、このブログを書いているときの理由です(2018- 03-14)、最新バージョンの ts-loader がインストールされました 4.0.1 の場合、プロジェクトを開始するとエラーが報告されます
オンデマンドで導入できるいくつかのライブラリもあります:
tslint: ts コードを標準化し、tsllint-loader と一緒に使用する必要があります。 tslint-config-standard を追加するのが最適です。
vue-property-decorator: vue-class-component の拡張機能。 Vue の機能を組み合わせるいくつかのデコレータ (@Emit、@Prop など) を追加します。
vuex -class: vue-class-component に基づいて vuex のサポートを強化します。
2. Webpack を設定します
次に、./build/webpack.base.conf.js ファイルを変更します:
そうする必要がないように、resolve.extension に「.ts」を追加します。 ts ファイルの .ts suffix をインポートするときに書き込みます
{ test: /\.tsx?$/, loader: 'ts-loader', exclude: /node_modules/, options: { appendTsSuffixTo: [/\.vue$/] } }
module.rules に webpack の ts ファイルの解析を追加します
3. その他の設定
プロジェクトのルート ディレクトリに tsconfig.json ファイルを作成します。
// tsconfig.json{ "compilerOptions": { // 与 Vue 的浏览器支持保持一致 "target": "es5", // 这可以对 `this` 上的数据属性进行更严格的推断 "strict": true, // 如果使用 webpack 2+ 或 rollup,可以利用 tree-shake: "module": "es2015", "moduleResolution": "node" } }完全な tsconfig .json 設定項目については、公式ドキュメントを参照してください ./src ディレクトリに vue-shim.d.ts ファイルを作成し、ts に .vue ファイルを認識させます:
// vue-shim.d.tsdeclare module "*.vue" { import Vue from "vue"; export default Vue; }
Four。ファイル変換
src ディレクトリの .vue ファイルを変更します。 すべての js ファイルのサフィックスを .ts.vue ファイルを導入するときは、.vue サフィックスを手動で追加する必要があります
すべての .vue ファイルは、<script> にある必要があります。 lang="ts" ロゴを </script>
に追加します。TypeScript が vue コンポーネント オプションで型を正しく推測できるようにするには、vue を導入する必要もあります。そして、Vue.extendを使用してコンポーネントを定義します5. クラスベースのVueコンポーネント変換
上面改造 .vue 文件的时候,只是简单的使用了 Vue.extend 方法,组件内部还是采用原生的 vue 写法
这在实际开发的时候并不能良好的使用 typescript 特性,所以还需要利用 vue-class-component 继续改造
首先在 tsconfig.json 中添加配置项,然后重启项目
// 允许从没有设置默认导出的模块中默认导入"allowSyntheticDefaultImports": true,// 启用装饰器"experimentalDecorators": true
然后改造 .vue 文件的 <script> 部分,以 HelloWorld.vue 为例:</script>
// HelloWorld.vue<script>import Vue from 'vue'import Component from 'vue-class-component'// @Component 修饰符注明了此类为一个 Vue 组件@Component({})export default class Hello extends Vue { msg: String = 'Welcome to Your Vue.js App'}</script>
组件内部不再采用 Vue 的格式,一开始也许不易接受,可以参考官方的迁移示例
<template> <p> <input> </p> <p>prop: {{propMessage}}</p> <p>msg: {{msg}}</p> <p>helloMsg: {{helloMsg}}</p> <p>computed msg: {{computedMsg}}</p> <button>Greet</button> </template> <script> msg = helloMsg = + + + </script>
六、使用TSlint 规范代码
如果对代码格式有着严格的要求,建议引入 tslint 来规范代码,首先安装以下依赖
npm init tslint tslint-loader tslint-config-standard -D
然后在 ./build/webpack.base.conf.js 的 module.rules 中添加规则
{ test: /\.ts$/, exclude: /node_modules/, enforce: 'pre', loader: 'tslint-loader'}
在项目根目录创建配置文件 tslint.json
// tslint.json{ "extends": "tslint-config-standard", "globals": { "require": true } }
这时已经可以启动项目了,如果出现了这样的警告
只需要在 main.ts 里面,将实例化的 Vue 赋值给一个对象就好
只是这里的 tslint 校验规则是直接引入的 standard 规范,如果需要自定义
贴一篇网上找的 tslint.json 的配置项说明(来源:http://blog.csdn.net/zw52yany/article/details/78688837)
extends: 内设配置项名称 rules: 规则 { //ts专用 adjacent-overload-signatures : true, // Enforces function overloads to be consecutive. ban-comma-operator:true, //禁止逗号运算符。 ban-type: [true, ["object","User {} instead."],["string"]] //禁止类型 member-access: [true , "no-public"||"check-accessor"|| "check-constructor" || "check-parameter-property" ] , //类成员必须声明 private public .... member-order: [true, {order:....}], //类声明排序 no-any: true,//不需使用any类型 no-empty-interface:true //禁止空接口 {} no-import-side-effect: [true, {"ignore-module": "(\\.html|\\.css)$"}], //禁止导入带有副作用的语句 no-inferrable-types:[true, "ignore-params", "ignore-properties"], //不允许将变量或参数初始化为数字,字符串或布尔值的显式类型声明。 no-internal-module:true, //不允许内部模块 no-magic-numbers: [true,1,2,3], //不允许在变量赋值之外使用常量数值。当没有指定允许值列表时,默认允许-1,0和1 no-namespace: [ true,"allpw-declarations"], //不允许使用内部modules和命名空间 no-non-null-assertion: true , //不允许使用!后缀操作符的非空断言。 no-parameter-reassignment: true, //不允许重新分配参数 no-reference: true, // 禁止使用/// <reference> 导入 ,使用import代替 no-unnecessary-type-assertion: true, //如果类型断言没有改变表达式的类型就发出警告 no-var-requires: true, //不允许使用var module = require("module"),用 import foo = require('foo')导入 only-arrow-functions:[true,"allow-declarations","allow-named-functions"], //允许箭头表达式,不需要传统表达式 ; 允许独立的函数声明 ;允许表达,function foo() {}但不是function() {} prefer-for-of:true, //建议使用for(..of) promise-function-async: true, 要求异步函数返回promise typedef: [true, "call-signature", "parameter", "member-variable-declaration"], //需要定义的类型存在 typedef-whitespace: true, //类型声明的冒号之前是否需要空格 unified-signatures: true, //重载可以被统一联合成一个 //function 专用 await-promise: true, //警告不是一个promise的await ban: [ true, "eval", {"name": "$", "message": "please don't"}, ["describe", "only"], {"name": ["it", "only"], "message": "don't focus tests"}, { "name": ["chai", "assert", "equal"], "message": "Use 'strictEqual' instead." }, {"name": ["*", "forEach"], "message": "Use a regular for loop instead."} ], curly: true, //for if do while 要有括号 forin:true, //用for in 必须用if进行过滤 import-blacklist:true, //允许使用import require导入具体的模块 label-postion: true, //允许在do/for/while/swith中使用label no-arg:true, //不允许使用 argument.callee no-bitwise:true, //不允许使用按位运算符 no-conditional-assignmen: true, //不允许在do-while/for/if/while判断语句中使用赋值语句 no-console:true, //不能使用console no-construct: true, //不允许使用 String/Number/Boolean的构造函数 no-debugger: true, //不允许使用debugger no-duplicate-super: true, //构造函数两次用super会发出警告 no-empty:true, //不允许空的块 no-eval: true, //不允许使用eval no-floating-promises: true, //必须正确处理promise的返回函数 no-for-in-array: true, //不允许使用for in 遍历数组 no-implicit-dependencies: true, //不允许在项目的package.json中导入未列为依赖项的模块 no-inferred-empty-object-type: true, //不允许在函数和构造函数中使用{}的类型推断 no-invalid-template-strings: true, //警告在非模板字符中使用${ no-invalid-this:true, //不允许在非class中使用 this关键字 no-misused-new: true, //禁止定义构造函数或new class no-null-keyword: true, //不允许使用null关键字 no-object-literal-type-assertion:true, //禁止objext出现在类型断言表达式中 no-return-await:true, //不允许return await arrow-parens: true, //箭头函数定义的参数需要括号 }</reference>
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上がVue と Typescript のビルド プロジェクトの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

はい、JavaScriptのエンジンコアはCで記述されています。1)C言語は、JavaScriptエンジンの開発に適した効率的なパフォーマンスと基礎となる制御を提供します。 2)V8エンジンを例にとると、そのコアはCで記述され、Cの効率とオブジェクト指向の特性を組み合わせて書かれています。3)JavaScriptエンジンの作業原理には、解析、コンパイル、実行が含まれ、C言語はこれらのプロセスで重要な役割を果たします。

JavaScriptは、Webページのインタラクティブ性とダイナミズムを向上させるため、現代のWebサイトの中心にあります。 1)ページを更新せずにコンテンツを変更できます。2)Domapiを介してWebページを操作する、3)アニメーションやドラッグアンドドロップなどの複雑なインタラクティブ効果、4)ユーザーエクスペリエンスを改善するためのパフォーマンスとベストプラクティスを最適化します。

CおよびJavaScriptは、WebAssemblyを介して相互運用性を実現します。 1)CコードはWebAssemblyモジュールにコンパイルされ、JavaScript環境に導入され、コンピューティングパワーが強化されます。 2)ゲーム開発では、Cは物理エンジンとグラフィックスレンダリングを処理し、JavaScriptはゲームロジックとユーザーインターフェイスを担当します。

JavaScriptは、Webサイト、モバイルアプリケーション、デスクトップアプリケーション、サーバー側のプログラミングで広く使用されています。 1)Webサイト開発では、JavaScriptはHTMLおよびCSSと一緒にDOMを運用して、JQueryやReactなどのフレームワークをサポートします。 2)ReactNativeおよびIonicを通じて、JavaScriptはクロスプラットフォームモバイルアプリケーションを開発するために使用されます。 3)電子フレームワークにより、JavaScriptはデスクトップアプリケーションを構築できます。 4)node.jsを使用すると、JavaScriptがサーバー側で実行され、高い並行リクエストをサポートします。

Pythonはデータサイエンスと自動化により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、データ処理とモデリングのためにNumpyやPandasなどのライブラリを使用して、データサイエンスと機械学習でうまく機能します。 2。Pythonは、自動化とスクリプトにおいて簡潔で効率的です。 3. JavaScriptはフロントエンド開発に不可欠であり、動的なWebページと単一ページアプリケーションの構築に使用されます。 4. JavaScriptは、node.jsを通じてバックエンド開発において役割を果たし、フルスタック開発をサポートします。

CとCは、主に通訳者とJITコンパイラを実装するために使用されるJavaScriptエンジンで重要な役割を果たします。 1)cは、JavaScriptソースコードを解析し、抽象的な構文ツリーを生成するために使用されます。 2)Cは、Bytecodeの生成と実行を担当します。 3)Cは、JITコンパイラを実装し、実行時にホットスポットコードを最適化およびコンパイルし、JavaScriptの実行効率を大幅に改善します。

現実世界でのJavaScriptのアプリケーションには、フロントエンドとバックエンドの開発が含まれます。 1)DOM操作とイベント処理を含むTODOリストアプリケーションを構築して、フロントエンドアプリケーションを表示します。 2)node.jsを介してRestfulapiを構築し、バックエンドアプリケーションをデモンストレーションします。

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

WebStorm Mac版
便利なJavaScript開発ツール

ホットトピック









