摘要:一般前端項目安裝依賴使用。包括,,以及程序主入口文件。然后頁面顯示正常。這樣就實現了使用構建一個項目,并簡單開發了一下,創建一個新的頁面并實現了路由跳轉。
一. 安裝 第一步:安裝npm所需模塊
首先需要安裝Node.js,然后使用npm安裝所需要的模塊
npm install -g grunt-cli bower yo generator-karma generator-angular第二步:創建工程
創建一個新的目錄,并在目錄下面運行
yo angular angular-project
angular-project是工程名字
然后會出現如下圖:
根據需要選擇使用Grunt還是Gulp,和是否需要Sass和Bootstrap。這里選擇了使用Grunt和Bootstrap。
Grunt和Gulp都是項目構建工具,不同的是Grunt是基于配置的,而Gulp是基于代碼的。
然后就是安裝過程,生成整個項目的框架,非常方便。
運行工程,Yeoman已經使用Grunt配置好了整個項目,只需要在控制臺輸入
grunt serve
瀏覽器就會自動打開窗口,http://localhost:9000,然后就可以看到網頁了。
主要開發就在app目錄下面,bower_components是安裝的依賴包,類似Node.js的node_modules,不同的是Node.js使用npm安裝,bower_components使用bower安裝。一般前端項目安裝依賴使用bower。使用npm安裝依賴包時,一個依賴可以有多個版本,而使用bower安裝時,同一個依賴不能有多個版本。使用bower安裝的依賴包可以在bower.json中看到。
Gruntfile.js是編譯工程的文件,這里有很多配置,包括server的配置等,所以這里沒有另外搭建后端server。
package.json是后端的依賴包,主要有Grunt的依賴包。
然后主要的開發就在app文件夾下,這里依次說明。
app/images:存儲網頁需要的圖片。
app/scripts:前端腳本。包括controllers,services,以及程序主入口app.js文件。
app/styles:CSS樣式文件。
app/views:靜態頁面文件。
app/404.html:頁面找不到時跳轉的頁面。
app/favicon.ico:頁面標題前的圖標。
app/index.html:在這里導入CSS樣式文件和所有腳本文件。
使用Yeoman可以很快的創建頁面對應的controller和路由。
1.安裝angular-ui-routerangular-ui-router是AngularJS的第三方路由模塊,比自帶的angular-route路由模塊好用,可以更好的實現頁面跳轉,嵌套路由。
安裝方法:
bower install angular-ui-router --save2.配置app/scripts/app.js文件
本來是這樣的
angular .module("angularProjectApp", [ "ngAnimate", "ngCookies", "ngResource", "ngRoute", "ngSanitize", "ngTouch" ]) .config(function ($routeProvider) { $routeProvider .when("/", { templateUrl: "views/main.html", controller: "MainCtrl", controllerAs: "main" }) .when("/about", { templateUrl: "views/about.html", controller: "AboutCtrl", controllerAs: "about" }) .otherwise({ redirectTo: "/" }); });
將"ngRoute"改為"ui.router",配置路由的格式也修改為
angular .module("angularProjectApp", [ "ngAnimate", "ngCookies", "ngResource", "ui.router", "ngSanitize", "ngTouch" ]) .config(["$stateProvider", "$urlRouterProvider", function ($stateProvider, $urlRouterProvider) { $urlRouterProvider.otherwise("/"); $stateProvider .state("main", { url: "/", templateUrl: "/views/main.html", controller: "MainCtrl" }) .state("about", { url: "/about", templateUrl: "/views/about.html", controller: "AboutCtrl" }}; }]);3.創建一個新的頁面
yo angular:route Page
可以看到app/scripts/controllers文件夾下多個一個page.js文件,
app/views文件夾下多了一個page.html文件,
app/index.html中增加了一行
index.html需要導入所有腳本文件,Yeoman幫我們自動導入了。
Yeoman還提供了很多自動創建的方法,
yo angular:controller [name], 自動創建一個controller
yo angular:directive [name],自動創建directive,directive可以自定義指令
yo angular:service [name],自動創建一個service,一般在service中向服務器端發送請求獲取數據
yo angular:filter [name],自動創建filter,filter實現對數據顯示的格式設置
yo angular:view [name],自動創建view
修改app/scripts/app.js文件
$stateProvider .state("main", { url: "/", templateUrl: "/views/main.html", controller: "MainCtrl" }) .state("about", { url: "/about", templateUrl: "/views/about.html", controller: "AboutCtrl" }) .state("page", { //此處為頁面名字,可以自定義頁面名字,在路由跳轉時使用 url: "page", //自定義路由 templateUrl: "/view/page.html", controller: "PageCtrl" });5.設置路由跳轉
在首頁上創建一個按鈕,跳轉到創建的page.html
然后在main.js中添加對應的按鈕事件
angular.module("angularProjectApp") .controller("MainCtrl", ["$scope", "$state", function ($scope, $state) { this.awesomeThings = [ "HTML5 Boilerplate", "AngularJS", "Karma" ]; $scope.goPage = function () { $state.go("page"); } }]);
首先通過依賴注入的方式注入兩個參數,$scope和$state。
$scope其實是一個對象,存儲當前頁面的數據和函數,可以看作是controller和view之前的橋梁。
$state的作用實現路由跳轉,通過$state.go("page")的形式就可以跳轉到page頁面。
"page"就是下面代碼第一行的頁面名字。
.state("page", { url: "/page", templateUrl: "/view/page.html", controller: "PageCtrl" });
在命令行運行
grunt serve
發現此時頁面成了這個樣子
查看控制臺也并沒有報錯,但是main.html的內容并沒有出現,檢查發現需要修改index.html,
將
這是angular-ui-router模塊和angular-route的不同之處。
然后頁面顯示正常。
點擊Go Page,也可以在瀏覽器地址欄直接輸入"http://localhost:9000/#!/page"
頁面跳轉到page頁面。
這樣就實現了使用Yeoman構建一個AngularJS項目,并簡單開發了一下,創建一個新的頁面并實現了路由跳轉。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/94217.html
摘要:承接前一篇做一個合格的前端,自動化構建工具入門教程故而整理了如下插件資源大全。接下來我會逐一開源觀點網開發過程中的前后端技術,如全文索引自定義富文本編輯器圖片上傳壓縮水印等等。 承接前一篇《做一個合格的前端,gulp自動化構建工具入門教程》故而整理了如下gulp插件資源大全。**【我的新作觀點網:http://www.guandn.com (觀點網是一個獵獲新奇、收獲知識、重在獨立思考...
摘要:包括腳手架依賴管理準備測試包括單元測試和端到端測試。我們用來開發的工具有。是一個工具集,包含個核心組件,,和腳手架工具。當你正在做自己的一個項目時,使用哪些模塊將取決于你自己。這個目錄當然是測試文件。 介紹 有很多可用的工具可以幫助你開發AngularJS 應用,那些非常復雜的框架不在我的討論范圍之中,這也是我開始這系列教程的原因。 在第一部分,我們掌握了AngularJS框架的基本...
摘要:什么是單頁面應用單頁面應用是指用戶在瀏覽器加載單一的頁面,后續請求都無需再離開此頁目標旨在用為用戶提供了更接近本地移動或桌面應用程序的體驗。流程第一次請求時,將導航頁傳輸到客戶端,其余請求通過獲取數據實現數據的傳輸通過或遠程過程調用。 什么是單頁面應用(SPA)? 單頁面應用(SPA)是指用戶在瀏覽器加載單一的HTML頁面,后續請求都無需再離開此頁 目標:旨在用為用戶提供了更接近本地...
摘要:什么是單頁面應用單頁面應用是指用戶在瀏覽器加載單一的頁面,后續請求都無需再離開此頁目標旨在用為用戶提供了更接近本地移動或桌面應用程序的體驗。流程第一次請求時,將導航頁傳輸到客戶端,其余請求通過獲取數據實現數據的傳輸通過或遠程過程調用。 什么是單頁面應用(SPA)? 單頁面應用(SPA)是指用戶在瀏覽器加載單一的HTML頁面,后續請求都無需再離開此頁 目標:旨在用為用戶提供了更接近本地...
閱讀 1729·2021-11-22 12:09
閱讀 1459·2019-08-30 13:22
閱讀 2092·2019-08-29 17:00
閱讀 2642·2019-08-29 16:28
閱讀 2954·2019-08-26 13:51
閱讀 1181·2019-08-26 13:25
閱讀 3243·2019-08-26 12:14
閱讀 3014·2019-08-26 12:14