首頁 web前端 js教程 使用AngularJS建立單頁應用的程式設計指引_AngularJS

使用AngularJS建立單頁應用的程式設計指引_AngularJS

May 16, 2016 pm 03:53 PM
angularjs

概述

單頁應用程式現在越來越受歡迎。模擬單頁應用程式行為的網站都能提供手機/平板電腦應用程式的感覺。 Angular可以幫助我們輕鬆創建此類應用程式
簡單應用

我們打算創建一個簡單的應用,涉及主頁,關於和聯繫我們頁面。雖然Angular是為創建比這更複雜的應用而生的,但本教程展示了許多我們在大型專案中需要的概念。
目標

  •         單頁應用程式
  •         無刷新式頁面變更
  •         每頁包含不同資料

雖然使用Javascript和Ajax可以實現上述功能,但是在我們的應用中,Angular可以使我們處理更容易。
文檔結構

  • - script.js            
  • - index.html            
  • - pages                
  • ----- home.html
  • ----- about.html
  • ----- contact.html


HTML頁面

這一部分比較簡單。我們使用Bootstrap和Font Awesome。打開你的index.html文件,然後我們利用導覽欄,加入一個簡單佈局。
 

<!-- index.html -->
<!DOCTYPE html>
<html>
<head>
 <!-- SCROLLS -->
 <!-- load bootstrap and fontawesome via CDN -->
 <link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" />
 <link rel="stylesheet" href="//netdna.bootstrapcdn.com/font-awesome/4.0.0/css/font-awesome.css" />
 
 <!-- SPELLS -->
 <!-- load angular via CDN -->
 <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.8/angular.min.js"></script>
 <script src="script.js"></script>
</head>
<body>
 
  <!-- HEADER AND NAVBAR -->
  <header>
    <nav class="navbar navbar-default">
    <div class="container">
      <div class="navbar-header">
        <a class="navbar-brand" href="/">Angular Routing Example</a>
      </div>
 
      <ul class="nav navbar-nav navbar-right">
        <li><a href="#"><i class="fa fa-home"></i> Home</a></li>
        <li><a href="#about"><i class="fa fa-shield"></i> About</a></li>
        <li><a href="#contact"><i class="fa fa-comment"></i> Contact</a></li>
      </ul>
    </div>
    </nav>
  </header>
 
  <!-- MAIN CONTENT AND INJECTED VIEWS -->
  <div id="main">
 
    <!-- angular templating -->
    <!-- this is where content will be injected -->
 
  </div>
 
  <!-- FOOTER -->
  <footer class="text-center">
    View the tutorial on <a href="http://scotch.io/tutorials/angular-routing-and-templating-tutorial">Scotch.io</a>
  </footer>
 
</body>
</html>
登入後複製

在頁面超連結中,我們使用"#"。我們不希望瀏覽器認為我們實際上是連結到about.html和contact.html。
Angular應用
模型與控制器

此時我們準備設定我們的應用程式。讓我們先來創建angular模型和控制器。關於模型和控制器,請查閱文件已獲得更多內容。

首先,我們需要用javascript來建立我們的模型和控制器,我們將此操作放到script.js:
 

// script.js
 
// create the module and name it scotchApp
var scotchApp = angular.module('scotchApp', []);
 
// create the controller and inject Angular's $scope
scotchApp.controller('mainController', function($scope) {
 
  // create a message to display in our view
  $scope.message = 'Everyone come and see how good I look!';
});
登入後複製

接下來讓我們把模型和控制器加入我們的HTML頁面中,這樣Angular可以知道如何引導我們的應用。為了測試功能有效,我們也會展示一個我們建立的變數$scope.message的值。
 

<!-- index.html -->
<!DOCTYPE html>
 
<!-- define angular app -->
<html ng-app="scotchApp">
<head>
 <!-- SCROLLS -->
 <!-- load bootstrap and fontawesome via CDN -->
 <link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" />
 <link rel="stylesheet" href="//netdna.bootstrapcdn.com/font-awesome/4.0.0/css/font-awesome.css" />
 
 <!-- SPELLS -->
 <!-- load angular via CDN -->
 <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.10/angular.min.js"></script>
   <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.2.10/angular-route.js"></script>
 <script src="script.js"></script>
</head>
 
<!-- define angular controller -->
<body ng-controller="mainController">
 
...
 
<!-- MAIN CONTENT AND INJECTED VIEWS -->
<div id="main">
  {{ message }}
 
  <!-- angular templating -->
  <!-- this is where content will be injected -->
</div>
登入後複製

在main這個div層中,我們現在可以看到我們建立的訊息。知道了我們的模型和控制器設定完畢並且Angular可以正常運行,那麼我們將要開始使用這一層來展示不同的頁面。

將頁面注入到主版面配置

ng-view 是一個用來包含當前路由(/home, /about, or /contact)的模板的angular指令, 它會獲得基於特定路由的文件並將其諸如到主佈局中(index.html ).

我們將會想div#main中的網站加入ng-view程式碼來告訴Angular將我們渲染的頁面放在哪裡.
 

<!-- index.html -->
...
 
<!-- MAIN CONTENT AND INJECTED VIEWS -->
<div id="main">
 
  <!-- angular templating -->
  <!-- this is where content will be injected -->
  <div ng-view></div>
 
</div>
 
...
登入後複製

設定路由與視圖

由於我們在創建一個單頁應用,並且不希望頁面刷新,那麼我們會用到Angular路由的能力。

讓我們來看看我們的Angular文件,並添加到我們的應用中。我們將會在Angular中使用$routeProvider來處理我們的路由。透過這種方式,Angular將會處理所有神奇的請求,透過取得一個新檔案並將其註入到我們的佈局中。

AngularJS 1.2 和路由

在1.1.6版本之後,ngRoute模型不在包含在Angular當中。你需要透過在文件開頭聲明該模型來使用它。教學已經為AngularJS1.2更新:
 

// script.js
 
// create the module and name it scotchApp
  // also include ngRoute for all our routing needs
var scotchApp = angular.module('scotchApp', ['ngRoute']);
 
// configure our routes
scotchApp.config(function($routeProvider) {
  $routeProvider
 
    // route for the home page
    .when('/', {
      templateUrl : 'pages/home.html',
      controller : 'mainController'
    })
 
    // route for the about page
    .when('/about', {
      templateUrl : 'pages/about.html',
      controller : 'aboutController'
    })
 
    // route for the contact page
    .when('/contact', {
      templateUrl : 'pages/contact.html',
      controller : 'contactController'
    });
});
 
// create the controller and inject Angular's $scope
scotchApp.controller('mainController', function($scope) {
  // create a message to display in our view
  $scope.message = 'Everyone come and see how good I look!';
});
 
scotchApp.controller('aboutController', function($scope) {
  $scope.message = 'Look! I am an about page.';
});
 
scotchApp.controller('contactController', function($scope) {
  $scope.message = 'Contact us! JK. This is just a demo.';
});
登入後複製

現在,我們已經透過$routeProvider定義了我們的路由。透過設定你會發現,你可以使用指定路由、模板檔案甚至是控制器。透過這種方法,我們應用的每一部分都會使用Angular控制器和它自己的視圖。


清理URL: angular預設會將一個井號放入URL中。為了避免這種事情,我們需要使用$locationProvider來啟用 HTML History API. 它將移除掉hash並建立出漂亮的URL。我們的主頁將會拉取home.html 檔案. About 和contact 頁面將會拉取它們關聯的檔案. 現在如果我們查看我們的應用,並點擊導航,我們的內容將會照我們的意思進行變更.

要完成這個教程,我們只需要定義好將會被注入的頁面就行了. 我們也將會讓它們每一個都展示來自與他們相關的控制器的消息.
 

<!-- home.html -->
<div class="jumbotron text-center">
  <h1>Home Page</h1>
 
  <p>{{ message }}</p>
</div>
 
<!-- about.html -->
<div class="jumbotron text-center">
  <h1>About Page</h1>
 
  <p>{{ message }}</p>
</div>
 
<!-- contact.html -->
<div class="jumbotron text-center">
  <h1>Contact Page</h1>
 
  <p>{{ message }}</p>
</div>
登入後複製

本地運行: Angular路由只會在你為其設定的環境後才會發揮作用。你要確保是使用的 http://localhost 或是某種類型的環境. 否則angular會說跨域請求支援HTTP.

Angular應用的動畫

一旦你把所有的路由都完成之後,你就能開始把玩你的站點並向其加入動畫了. 為此,你需要使用angular提供的ngAnimate 模組. 後面你就可以用CSS動畫來用動畫的方式切換視圖了. 
單一頁App上的SEO

理想情況下,此技術可能會被用在有使用者登入後的應用程式中。你當然不會真的想要特定用戶私人性質的頁面被搜尋引擎索引. 例如,你不會想要你的讀者帳戶,Facebook登入的頁面或部落格CMS頁面被索引到.

如果你確實像針對你的應用程式進行SEO,那麼如何讓SEO在使用js建立頁面的應用程式/網站上起效呢? 搜尋引擎難於處理這些應用程式因為內容是由瀏覽器動態建構的,而且對爬蟲是看不見的.

讓你的應用程式對SEO友善

使得js單頁應用對SEO友好的技術需要定期做維護. 根據官方的Google 建議, 你需要創建HTML快照. 其如何運作的概述如下:

  •     爬蟲會發現一個友善的URL(http://scotch.io/seofriendly#key=value)
  •     然後爬蟲會想伺服器請求對應這個URL的內容(用一種特殊的修改過的方式)
  •     Web伺服器會使用一個HTML快照回傳內容
  •     HTML快照會被爬蟲處理
  •     然後搜尋結果會顯示原來的URL

更多關於這個過程的信息,可以去看看Google的 AJAX爬蟲 和他們有關創建HTML快照 的指南.

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1317
25
PHP教程
1268
29
C# 教程
1246
24
2022年最新5款的angularjs教學從入門到精通 2022年最新5款的angularjs教學從入門到精通 Jun 15, 2017 pm 05:50 PM

Javascript 是一個非常有個性的語言. 無論是從程式碼的組織, 還是程式碼的程式設計範式, 或物件導向理論都獨具一格. 而很早就在爭論的Javascript 是不是物件導向語言這個問題, 顯然已有答案. 但是, 即使Javascript 叱吒風雲二十年, 如果想要看懂jQuery, Angularjs, 甚至是React 等流行框架, 觀看《黑馬雲課堂JavaScript 高級框架設計視頻教程》就對了。

使用PHP和AngularJS建立響應式網站,提供優質的使用者體驗 使用PHP和AngularJS建立響應式網站,提供優質的使用者體驗 Jun 27, 2023 pm 07:37 PM

在現今資訊時代,網站已成為人們獲取資訊和交流的重要工具。一個響應式的網站能夠適應各種設備,為使用者提供優質的體驗,成為了現代網站開發的熱點。本篇文章將介紹如何使用PHP和AngularJS建立響應式網站,進而提供優質的使用者體驗。 PHP介紹PHP是一種開源的伺服器端程式語言,非常適合Web開發。 PHP具有許多優點,如易於學習、跨平台、豐富的工具庫、開發效

使用PHP和AngularJS建立Web應用 使用PHP和AngularJS建立Web應用 May 27, 2023 pm 08:10 PM

隨著網路的不斷發展,Web應用已成為企業資訊化建設的重要組成部分,也是現代化工作的必要手段。為了讓Web應用能夠方便開發、維護和擴展,開發人員需要選擇適合自己開發需求的技術框架和程式語言。 PHP和AngularJS是兩種非常流行的Web開發技術,它們分別是伺服器端和客戶端的解決方案,透過結合使用可以大大提高Web應用的開發效率和使用體驗。 PHP的優勢PHP

使用Flask和AngularJS建立單頁Web應用程式 使用Flask和AngularJS建立單頁Web應用程式 Jun 17, 2023 am 08:49 AM

隨著Web技術的快速發展,單頁Web應用程式(SinglePageApplication,SPA)已成為越來越流行的Web應用程式模型。相較於傳統的多頁Web應用程序,SPA的最大優勢在於使用者感受更加流暢,同時伺服器端的運算壓力也大幅減少。在本文中,我們將介紹如何使用Flask和AngularJS來建構一個簡單的SPA。 Flask是一款輕量級的Py

AngularJS基礎入門介紹 AngularJS基礎入門介紹 Apr 21, 2018 am 10:37 AM

這篇文章介紹的內容是關於AngularJS基礎入門介紹,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下。

如何使用PHP和AngularJS進行前端開發 如何使用PHP和AngularJS進行前端開發 May 11, 2023 pm 05:18 PM

隨著網路的普及和發展,前端開發已變得越來越重要。身為前端開發人員,我們需要了解並掌握各種開發工具和技術。其中,PHP和AngularJS是兩種非常有用且受歡迎的工具。在本文中,我們將介紹如何使用這兩種工具進行前端開發。一、PHP介紹PHP是一種流行的開源伺服器端腳本語言,它適用於Web開發,可以在Web伺服器和各種作業系統上運作。 PHP的優點是簡單、快速、便

如何在PHP編程中使用AngularJS? 如何在PHP編程中使用AngularJS? Jun 12, 2023 am 09:40 AM

隨著Web應用程式的普及,前端框架AngularJS變得越來越受歡迎。 AngularJS是一個由Google開發的JavaScript框架,它可以幫助你建立具有動態Web應用程式功能的網頁應用程式。另一方面,對於後端編程,PHP是非常受歡迎的程式語言。如果您正在使用PHP進行伺服器端編程,那麼結合AngularJS使用PHP將可以為您的網站帶來更多的動態效

使用PHP和AngularJS開發一個線上文件管理平台,方便文件管理 使用PHP和AngularJS開發一個線上文件管理平台,方便文件管理 Jun 27, 2023 pm 01:34 PM

隨著網路的普及,越來越多的人使用網路進行檔案傳輸和分享。然而,由於各種原因,使用傳統的FTP等方式進行檔案管理無法滿足現代使用者的需求。因此,建立一個易用、高效、安全的線上文件管理平台已成為了一種趨勢。本文介紹的線上文件管理平台,基於PHP和AngularJS,能夠方便地進行文件上傳、下載、編輯、刪除等操作,並且提供了一系列強大的功能,例如文件共享、搜尋、

See all articles