angular.js - Angular路由和express路由的組合使用問題
問題描述
想用Angular的路由里面監聽url變化來獲取不同的ejs模版,但是當url一變化express的路由也會作出反應,想問下該怎么做才能在url變成/phone時不進入express的路由。
public/javascript/app.js
angular.module(’ngApp’,[]).config([’$routeProvider’,function($routeProvider) { $routeProvider.when(’/’, {templateUrl: ’pages/index’,controller: ’PhoneListCtrl’}).when((’/phone’, {templateUrl: ’pages/phone-detail’,controller: ’PhoneDetCtrl’})).otherwise({redirectTo: ’/’})}])
routes/index.js
var express = reqsuire(’express’);var router = express.Router();router.get(’/pages/phone-detail’, function(req, res, next) { res.render('phone-detail', {title: ’艾希’});})module.exports = router;
下面圖片是結構,模版都在view/pages下
問題解答
回答1:兩個問題1.angularjs和ejs怎么想都感覺重復了,用angularjs的話就可以使用html+ajax方式,用ejs就可以使用ejs+ajax,說起來不用兩個都用。2.按說兩個都用,angularjs的route設置,加載的頁面是將子頁面異步加載到父頁面的<ng-view>中的,而ejs是整個瀏覽器窗口的渲染,相當于跳頁面了,確實會有沖突。
我暫時能想到的解決方法是,主頁面用ejs跳轉,子頁面采用ng-route進行異步加載,但是缺點就是在ejs和angular的route設置中不能設置otherwise。
相關文章:
1. node.js - 如何用nodejs寫一個接口,隨便寫一個就好2. java - 請問在main方法中寫成對象名.屬性()并賦值,與直接參參數賦值輸錯誤是什么原因?3. node.js - node_moduls太多了4. 這段代碼既不提示錯誤也看不到結果,請老師明示錯在哪里,謝謝!5. html - jQuery 移動端橫向滾動會帶動網頁上下滑動怎么辦?6. myeclipse中有AB兩個項目,A項目的java文件用GBK編碼,B項目用utf-8編碼,怎么辦?7. node.js - webpack-dev-server正常運行,webpack打包卻出錯,怎么辦?8. node.js - nodejs debug問題9. javascript - iscroll實例化未知個數的內容塊時怎么辦?10. objective-c - iOS 開發中 WKWebView 的使用問題攔截跳轉
