摘要:環(huán)境搭建今天給大家介紹種環(huán)境搭建的方法。官方的地址步驟安裝種子文件沒有的,可以自己下來,然后打開,執(zhí)行。使用版本為版本。存放表單相關內置組件與指令。存放網絡請求相關的服務等。等待加載完畢即可。從而實現(xiàn)了頁面的顯示
1:環(huán)境搭建
今天給大家介紹4種環(huán)境搭建的方法。
官方指導文檔:www.angular.cn/guide/quickstart
請使用cnpm來安裝,或者配置淘寶鏡像。
使用原生npm安裝可能會遇到的問題:
需要python的環(huán)境
可能會依賴某些franework導致會要求安裝Visual Studio(在下文中會為大家介紹webstrom的配置)
node-sass // 因為ZF導致,被墻掉了。
node-gyp模塊可能會編譯錯誤。
如果還遇到問題可以參考:http://blog.csdn.net/zhy13087...
Angular的種子文件,他有很多的版本,我們今天通過官方的seed來安裝。
官方的angular-seed地址:https://github.com/angular/an...
步驟:
git clone https://github.com/angular/an...安裝種子文件(沒有git的,可以自己down zip下來,然后打開cmd,執(zhí)行cnpm install)。
前置需安裝的包文件
npm install -g webpack webpack-dev-server typescript
npm install
npm start
訪問本地 localhost:3000
seed文件的優(yōu)點:
自帶簡單的路由
自帶From模塊
帶有Http請求模塊
體現(xiàn)出了Angular的核心功能
項目體量小
優(yōu)點:可以讓我們自由的配置webpack.config.js
步驟:https://github.com/kunl/Angul...
場景:從Node轉到前端的公司或者項目推薦用這種方式
條件:大神級別的使用方法(我不是大神,會簡單的介紹一下)
優(yōu)點:想要什么在項目中添加什么,非??旖?/p>
步驟:
準備工作:
在開始搭建Angular環(huán)境前,還需要做一些準備工作,包括安裝Angular所依賴的基礎環(huán)境Node.js,可以在官網(https://nodejs.org/en/download/)下載安裝,需要確認Node.js版本為v4.x.x以上,npm版本為v3.x.x以上。使用版本為node v5.11.0版本。
搭建步驟
1: 創(chuàng)建package.json
{ "name": "HelloByHand", "version": "1.0.0", "license": "MIT", "scripts": { "start": "npm run server", "server": "webpack-dev-server –inline –colors –progress –port 3000" }, "dependencies": { "@angular/common": "2.0.0", "@angular/compiler": "2.0.0", "@angular/core": "2.0.0", "@angular/platform-browser": "2.0.0", "@angular/platform-browser-dynamic": "2.0.0", "reflect-metadata": "~0.1.8", "core-js": "~2.4.1", "rxjs": "5.0.0-beta.12", "zone.js": "~0.6.26" }, "devDependencies": { "@types/core-js": "~0.9.34", "ts-loader": "~1.2.0", "webpack": "~1.12.9", "webpack-dev-server": "~1.14.0", "typescript": "~2.0.0" } }
2:創(chuàng)建tsconfig.json
配置了typescript編譯器的編譯參數(shù)。
{ "compileOnSave": true, "compilerOptions": { "module": "commonjs", "target": "es5", "sourceMap": true, "declaration": false, "moduleResolution": "node", "emitDecoratorMetadata": true, "experimentalDecorators": true, "removeComments":false, "noImplicitAny": true, "suppressExcessPropertyErrors": true, "typeRoots": [ "node_modules/@types" ], "exclude": [ "node_modules" ] } }
3:創(chuàng)建資源文件夾
在項目根目錄下創(chuàng)建一個src文件夾4:創(chuàng)建組件相關文件
在src目錄下創(chuàng)建app.component.ts文件以及模板文件app.component.html,示例代碼如下:
//app.component.ts import { Component } from "@angular/core"; @Component({ selector: "hello-world", templateUrl: "scr/app.component.ts" }) export class AppComponent {} //app.component.htmlHello World
5:創(chuàng)建app.module.ts文件
在Angular應用中需要用模塊來組織一些功能緊密相關的代碼塊,每個應用至少有一個模塊,習慣上把它叫做AppModule。在src目錄下創(chuàng)建一個app.module.ts文件來定義AppModule,代碼如下:
import { BrowserModule } from "@angular/platform-browser"; import { NgModule } from "@angular/core"; import { AppComponent } from "./app.component"; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule ], providers: [], bootstrap: [AppComponent] }) export class AppModule { }
6: 添加main.ts文件
Angular項目一般有一個入口文件,通過這個文件來串聯(lián)起整個項目。示例代碼如下:
//main.ts import "reflect-metadata"; import "zone.js"; import { platforBrowserDynamic } from "@angular/platform-browser-dynamic"; import { AppModule } from "./app.module"; platforBrowserDynamic().bootstrapModule(AppModule).catch(err => console.log(err));
7:創(chuàng)建index.html宿主頁面
MyApp 加載中....
8:創(chuàng)建webpack.config.js
//webpack.config.js var webpack = require("webpack"); var path = require("path"); module.exports = { entry: "./scr/main.js" output: { filename: "./bundle.js" }, resolve: { root: [path.join(__dirname, "scr")], extensions: ["", ".ts", ".js"] }, module: { loaders: [ { test: /.ts$/, loader: "ts-loader" } ] } }
重點:一個Angular項目必須要有一個模塊和一個組件。
2:詳細介紹Angular-cli命令行工具官方文檔:https://github.com/angular/an...
創(chuàng)建項目和組件:
ng new (創(chuàng)建angular項目)
ng generate (創(chuàng)建項目中的組件等內容)
具體操作如下圖:
http://chuantu.biz/t6/44/1505...
啟動服務:
ng serve --open (--open是在瀏覽器中打開的意思)
測試和打包
ng test
ng build
3: Angular文件結構分析特點跟特性:借助了 Amber Cli (負責:項目構建、項目的組織架構等) / WebPack(負責:調試、打包、測試)
以Angular-cli創(chuàng)建的項目目錄為基礎。
e2e 文件端對端測試
src 我們主要的開發(fā)代碼的存放位置
angular-cli.json angular-cli配置
karma.config.js 單元測試文件
package.json npm包管理配置
Protractor.conf.js 這也是測試的相關文件
README.md 有我們的cli說明
Tsconfig.json 我們的Typescript配置
Tslint.json 是我們Typescipt代碼格式校驗文件
src 目錄下結構
app 根模塊、根組件
assets 放圖片、字體文件等等
environments 配置環(huán)境。生成環(huán)境、開發(fā)環(huán)境、測試環(huán)境
index.html 單應用的唯一頁面
main.ts 整個項目的入口腳本
polyfills.ts 兼容老版本的瀏覽器
styles.css 全局樣式配置
test.ts 測試用例的ts
4:源碼的位置分析@angular/core 存放核心代碼,如變化監(jiān)測機制、依賴注入機制、渲染等,核心功能的實現(xiàn),裝飾器也會存放在這個模塊。
@angular/common 存放一些常用的內置指令和內置管道等。
@angular/froms 存放表單相關內置組件與指令。
@angular/http 存放網絡請求相關的服務等。
@angular/router 存放路由相關
@angular/platform-
選擇File -> settings -> Languages & Frameworks -> Javascript,選擇編譯方式為ECMAScript 6。
選擇File -> settings -> Languages & Frameworks -> Javascript->Libraries ->右側面板選擇 Add ->在彈出框中選擇綠色加號,再選擇目錄 ->在彈出的窗口中選擇當前項目下的node_modules 文件夾 ->一路ok和apply。等待IDE加載完畢即可。
6: Bootstrap等插件的安裝使用我們使用bootstrap的樣式,在控制層方面(bootstrap涉及到js的地方)我們使用ngx-bootstrap。
官方地址:http://valor-software.com/ngx...涉及到javascript操作的部分在這個鏈接里找解決方案。
AngularCli項目集成Bootstrap步驟:
npm install ngx-bootstrap bootstrap –save
在項目目錄下的 .angular-cli.json中的“styles”參數(shù)中添加:
"../node_modules/bootstrap/dist/css/bootstrap.min.css"
重啟項目就可以直接使用bootstrap的樣式了,例如form-group,btn…
7:啟動過程詳解需要掌握的內容:
啟動時加載哪兒頁面。(index.html)
啟動時加載哪個腳本。(main.ts)
啟動時做了什么事情。
第三個問題要從main.ts來分析重點:
在main.ts中platformBrowserDynamic是動態(tài)引導項目加載。會把項目指引到AppModule中去。
AppModule中的bootstrap元數(shù)據(jù),會指定模塊的根組件也就是app.component.ts
根組件暴露出select選擇器為app-root。而index.html中加載了
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/91949.html
摘要:可以說,如果問題是我們的敵人,代碼是我們的劍,設計模式就是高手心中的劍譜。中級選手,在編程的時候知道何時該用什么設計模式,而什么時候不該用。設計模式被用來簡化設計,讓設計更優(yōu)雅。其中最具有普遍性的方案往往就是我們的設計模式的內容。 showImg(https://segmentfault.com/img/remote/1460000019100076?w=800&h=440); 目錄概...
摘要:由于線性回歸作用于股票收盤價的整個周期,因此選擇合適的時間段非常重要。在制定量化交易策略時有一種方式是尋找現(xiàn)象中的特征,根據(jù)特征去生成交易條件。 新年伊始,很榮幸筆者的《教你用 Python 進階量化交易》專欄在慕課專欄板塊上線了,歡迎大家訂閱!為了能夠提供給大家更輕松的學習過程,筆者在專欄內容之外會陸續(xù)推出一些手記來輔助同學們學習本專欄內容,因此同學們無需擔心專欄內容在學習上的困難,...
摘要:畢設做的是的相關研究,翻過一些資料,在此做個匯總。深度學習的介紹性文章,可做入門材料。可以當作深度學習的學習材料。一份訓練的較佳實踐。闡述了非監(jiān)督預訓練的作用。這篇博客給出的材料更加全面,作者來自復旦大學,現(xiàn)似乎是在北京研究院工作。 畢設做的是DBNs的相關研究,翻過一些資料,在此做個匯總。 可以通過谷歌學術搜索來下載這些論文。 Arel, I., Rose,...
摘要:隨后深度學習的研究大放異彩,廣泛應用在了圖像處理和語音識別領域。比如的學生就用深度學習算法贏得年的。深度學習和人工智能的春天離人工智能最近的互聯(lián)網公司敏銳嗅到了這一機遇。 多倫多大學計算機系教授Geoffrey Hinton是Deep Learning的開山鼻祖,我們來講講他的故事。他有個傳奇的姑姑不過先來說說他姑姑吧,他姑姑Joan Hinton是一個與中國有關的具有傳奇經歷的人物,中文名...
閱讀 1576·2021-10-25 09:44
閱讀 2941·2021-09-04 16:48
閱讀 1571·2019-08-30 15:44
閱讀 2513·2019-08-30 15:44
閱讀 1743·2019-08-30 15:44
閱讀 2829·2019-08-30 14:14
閱讀 2980·2019-08-30 13:00
閱讀 2158·2019-08-30 11:09