摘要:該內(nèi)的內(nèi)容會根據(jù)路由的變化而變化。配置,用來定義路由規(guī)則。由此我們就需要另一個第三方路由模塊,叫做,當然它是基于開發(fā)的。造成這種現(xiàn)象的最根本原因路由沒有明確的父子層級關(guān)系。監(jiān)聽路由路由狀態(tài)發(fā)生改變時可以通過監(jiān)聽,通過注入實現(xiàn)狀態(tài)的管理。
何為路由
路由機制運可以實現(xiàn)多視圖的單頁Web應(yīng)用(single page web application,SPA)。
單頁應(yīng)用在使用期間不會重新加載頁面,所有的數(shù)據(jù)交互由ajax完成。
非單頁應(yīng)用請求不同url,對SEO很不友善,而且刷新或發(fā)送url無法保留瀏覽進度。
而單頁應(yīng)用前端擁有監(jiān)管url的權(quán)利,通過監(jiān)聽頁面地址變化來調(diào)用前端MVC模塊,渲染不同頁面。當然,前端這時也擁有了修改URL的能力,只需要管理好前端視圖與URL。在確定了需要保持的頁面后,前后端圍繞頁面各自負責視圖的渲染。
路由實現(xiàn) url不變話化這一種的情況是url完全不變,即你的頁面怎么改變,怎么跳轉(zhuǎn)url都不會改變。
這種情況的原理 就是純ajax拿到頁面模板后替換原頁面中的元素,重現(xiàn)渲染頁面。然而ajax的一個致命缺點就是導(dǎo)致瀏覽器后退按鈕失效。用戶體驗很不好。
這種類型的優(yōu)點就是刷新頁面,頁面也不會丟。關(guān)于hash值的介紹鏈接
通過監(jiān)聽 hash(#)的變化來執(zhí)行js代碼 從而實現(xiàn) 頁面的改變
核心代碼:
window.addEventListener("hashchange",function(){ //code })
就是通過這個原理 只要#改變了 就能觸發(fā)這個事件,這也是很多單頁面網(wǎng)站的url中都也 (#)的原因
h5 history api這種類型是通過html5的最新history api來實現(xiàn)的。
通過pushState()記錄操作歷史,監(jiān)聽window.onpopstate事件來進行視圖切換,能正常的回退前進。
這里是關(guān)于 history api的連接
關(guān)于這三種方法的demo往后會給大家提供完善,大家可以提醒我。
AngularJS 路由AngularJS 路由就是通過通過hash和h5 history兩種方式實現(xiàn)的,允許我們通過不同的 URL 訪問不同的內(nèi)容。
通常我們的URL形式為 http://runoob.com/first/page,但在單頁Web應(yīng)用中 AngularJS 通過 # + 標記 實現(xiàn),例如:
http://cds.com/#/firstPage http://cds.com/#/secondPage
當我們點擊以上的任意一個鏈接時,向服務(wù)端請的地址都是一樣的 (http://runoob.com/)。 因為 # 號之后的內(nèi)容在向服務(wù)端請求時會被瀏覽器忽略掉。 所以我們就需要在客戶端實現(xiàn) # 號后面內(nèi)容的功能實現(xiàn)。
AngularJS 路由通過 # + 標記 幫助我們區(qū)分不同的邏輯頁面并將不同的頁面(View)綁定到對應(yīng)的控制器(controller)上。
下面我們介紹一下Angular的路由實現(xiàn)。
ngRouterngRouter是angular的一個多帶帶模塊。
我們看看他是怎么實現(xiàn)的。
1、加載實現(xiàn)路由的 js 文件:angular-route.js。
2、包含了 ngRoute 模塊作為主應(yīng)用模塊的依賴模塊。(為什么這么寫,下文介紹)
angular.module("routingDemoApp",["ngRoute"])
3、使用 ngView 指令。
該 div 內(nèi)的 HTML 內(nèi)容會根據(jù)路由的變化而變化。
4、配置 $routeProvider,AngularJS $routeProvider 用來定義路由規(guī)則。
angular.module("MyApp", ["ngRoute"]).config(["$routeProvider", function($routeProvider){ //$routeProvider 為我們提供了 when(path,object) & otherwise(object) 函數(shù)按順序定義所有路由,函數(shù)包含兩個參數(shù):第一個參數(shù)是 URL 或者 URL 正則規(guī)則。第二個參數(shù)是路由配置對象。 $routeProvider.when(url, { template: string,//在 ng-view 中插入簡單的 HTML 內(nèi)容 templateUrl: string,//在 ng-view 中插入 HTML 模板文件 controller: string, function 或 array,//在當前模板上執(zhí)行的controller函數(shù),生成新的scope。 controllerAs: string,//為controller指定別名。 redirectTo: string, function,//重定向的地址。 resolve: objectUI-Router//指定當前controller所依賴的其他模塊。 }); $routeProvider.otherwise({redirectTo:"/"})//除配置路由外的其他路徑指向 }]);
在使用ngRouter時往往不能進行視圖嵌套,而且功能有限,不能滿足開發(fā)需求。由此我們就需要另一個第三方路由模塊,叫做 ui.router ,當然它是基于ngRouter開發(fā)的。
ui.Router提供了一種很好的機制,可以實現(xiàn)深層次嵌套。
1、在引入ui.route路由源文件
2、加載依賴模塊
angular.module("myApp", ["ui.router"]); // myApp為自定義模塊,依賴第三方路由模塊ui.router
在程序啟動(bootstrap)的時候,加載依賴模塊(如:ui.router),將所有 掛載 在該模塊的 服務(wù)(provider) , 指令(directive) , 過濾器(filter) 等都進行注冊 ,那么在后面的程序中便可以調(diào)用了。
angular.module("myApp", ["ui.router","myFilter","myDirective","myService"]); //實際中只要依賴首頁需要用的模塊就可以。
3、定義視圖
//視圖展示 dash頁//定義導(dǎo)航
在視圖模板中還可以包含自己的 ui-view ,這就是我們可以支持嵌套路徑的原因。
4、配置 $stateProvider,在ui.router通過$stateProvider來定義路由規(guī)則
angular.module("MyApp").config(["$stateProvider", "$urlRouterProvider", function ($stateProvider, $urlRouterProvider) { //$stateProvider為我們提供了state(pathName,object) & otherwise(object) 函數(shù)按順序定義所有路由,函數(shù)包含兩個參數(shù):第一個參數(shù)是 URL名稱(視圖中導(dǎo)航名稱)。第二個參數(shù)是路由配置對象。 $urlRouterProvider.otherwise("/dash.html"); //定義默認跳轉(zhuǎn)和除配置之外的定向路由 $stateProvider .state("dash"(string), {//導(dǎo)航用的名字,如dash里的login url: "/dash.html"(string),//訪問路徑,可視的路徑 template: string,//在 ui-view 中插入簡單的 HTML 內(nèi)容 templateUrl: "views/dash.html"(string),//在 ui-view 中插入 HTML 模板文件(靜態(tài)文件路徑) data: {pageTitle: "系統(tǒng)主頁"}(object可以多層嵌套),//data數(shù)據(jù)不會注入到控制器,可以從父狀態(tài)向子狀態(tài)傳遞數(shù)據(jù) controller: "DashController",//在當前模板上執(zhí)行的controller函數(shù),生成新的scope。 params:object,//params 選項是參數(shù)名稱(下文有栗子)。當狀態(tài)激活的時候,應(yīng)用會使用這些參數(shù)填充 $stateParams 服務(wù)。 resolve: { deps: ["$ocLazyLoad", function ($ocLazyLoad) {//"$ocLazyLoad"是controller的依賴模塊,返回執(zhí)行方法。AngularJs 通過 ocLazyLoad 實現(xiàn)動態(tài)(懶)加載模塊和依賴。具體的有時間再擴展。留個鏈接!!! return $ocLazyLoad.load({ name: "MetronicApp", insertBefore: "#ng_load_plugins_before", files: [ "app/controllers/DashController.js", ] }); }] }//在下文介紹 }) }]);
resolve 功能路由嵌套
使用 resolve 功能,我們可以準備一組用來注入到控制器中的依賴對象,在 uiRoute 中,resolve 可以在路由實際渲染之前解決掉 promise。
resolve 選項提供一個對象,對象中的 key 就是準備注入 controller 的依賴名稱,值則是創(chuàng)建對象的工廠。
如果是一個字符串,就試圖用這個串來匹配當前已經(jīng)注冊的服務(wù)名稱,
如果是一個函數(shù),執(zhí)行這個函數(shù),返回的值就是依賴。
如果函數(shù)返回一個 promise,在控制器被實例化之前,將會被 resolved,返回的值被注入到 controller中。
先說說為什么要視圖嵌套,頁面一個主區(qū)塊顯示主內(nèi)容,主內(nèi)容中的部分內(nèi)容要求根據(jù)路由變化而變化,這時就需要另一個動態(tài)變化的區(qū)塊嵌套在主區(qū)塊中。
如果用ngRoute 實現(xiàn)視圖嵌套,你會發(fā)現(xiàn)是不可能的,因為在ng-view指令link的過程中,代碼會無限遞歸下去。造成這種現(xiàn)象的最根本原因:路由沒有明確的父子層級關(guān)系。
而uiRouter很好的解決了這一問題。
慣例先上代碼:
$stateProvider .state("parent", { abstract: true,//可以通過它解決依賴問題,或者特定數(shù)據(jù)處理,或者簡單地同樣的 url 來嵌套多個路由,例如,所有路由都在 /parent下面。 url: "/parent",//相對路徑=>…./index.html#/parent template: "I am parent "http://當然你也可以寫在templateUrl中 }) .state("parent.child", { url: "/child",//相對路徑=>…./index.html#/parent/child url:"^/child",//絕對路徑=>…./index.html#/child 注意寫法區(qū)別 template: "I am child" }); 點我顯示父view內(nèi)容 點我顯示父view與子view內(nèi)容
巧妙地,通過 parent 與 parent.child 來確定路由的 父子關(guān)系 ,從而解決無限遞歸問題。另外子路由的模板最終也將被插入到父路由模板的div[ui-view]中去,從而達到視圖嵌套的效果。
多視圖效果多視圖:頁面可以顯示多個動態(tài)變化的不同區(qū)塊。
原因在于,在ui.router中:可以給視圖命名(字符串),如:ui-view="status"。可以在路由配置中根據(jù)視圖名字(如:status),配置不同的模板(其實還有controller等)。
放一段代碼
var app = angular.module("myApp", ["ui.router"]); app.config(["$stateProvider", function ($stateProvider) { $stateProvider .state("index", { url: "/index", views:{ "header":{template:"頭部內(nèi)容"}, "nav":{template:"菜單內(nèi)容"}, "body":{template:"展示內(nèi)容"} } }) }]);
待完善(項目無涉及)(控制起來也很麻煩,處理不好都是坑,如果要用到再完善吧。)
視圖定位@的作用 是用來絕對定位view,即說明該ui-view屬于哪個模板。
同樣放一段代碼
show index content111111 content222222var app = angular.module("myApp", ["ui.router"]); app.config(["$stateProvider", function ($stateProvider) { $stateProvider .state("index", { url: "/index", views:{ "index":{template:""}, //這里必須要絕對定位 "header@index":{template:"頭部內(nèi)容header"}, "nav@index":{template:"菜單內(nèi)容nav"}, "body@index":{template:"展示內(nèi)容contents"} } }) //絕對定位 .state("index.content1", { url: "/content1", views:{ "body@index":{template:"content11111111111111111"} //"body@index"表時名為body的view使用index模板 } }) //相對定位:該狀態(tài)的里的名為body的ui-view為相對路徑下的(即沒有說明具體是哪個模板下的) .state("index.content2", { url: "/content2", views:{ "body":{template:"content2222222222222222222"}// } }) }]);待完善(項目無涉及)(其實也不難理解,只是這個時間段任務(wù)重了,這里有時間再了解完善啊)。
路由傳參Angular應(yīng)用通過通過$stateParams服務(wù)獲取參數(shù)他有兩種方式:(相對溫習(xí)一下路徑穿參方式,$location.search())
1.url: "/index/:id"
2.url: "/index/{id}"
注意這里只是兩種不同寫法angular.module("MetronicApp").config(["$stateProvider", "$urlRouterProvider", function ($stateProvider, $urlRouterProvider) { $stateProvider .state("dash", { url: "/dash.html/:orderId/:projectId", //或者注意是或者(這種需要直接定義好,或由頁面?zhèn)髦担? url:"/dash.html/{orderId}", //如果應(yīng)用訪問 /dash.html/42,那么,$stateParameter.orderId 就成為 42, 實際上, $stateParams 的值將為 { orderId: 42 } //或者(這種是在路由中定義好參數(shù)) url:"/dash.html", params: { orderId: { value: 42} } templateUrl: "/dash.html", controller: function ($stateParams,$scope) { //可以注入$stateParams服務(wù)來獲取你所傳遞的服務(wù) $scope.projectId=$stateParams.projectId; $scope.orderId=$stateParams.orderId; //42 } }) }]); //然后大家在看頁面中的寫法 也是兩種方式建議用第二種() href傳參數(shù) ui-sref傳參數(shù)再來擴展一下,在控制器中的頁面跳轉(zhuǎn),并且傳參
angular.module("MetronicApp",["ui.router"]); angular.module("MetronicApp").controller("MyCtrl", function($scope, $state,$location) { $scope.pathChange = function() { $state.go("dash",{name: 42}); //第一個參數(shù)是定義的urlName,第二個為參數(shù) }; $scope.pathChange = function() { $location.path("/sixth/detail/42"); //$location服務(wù)中有介紹 }; });可能大家會有疑問,我們項目的路徑和這個示例不一樣,這里的參數(shù)是angular是控制路徑跳轉(zhuǎn)的參數(shù)目的在與定向視圖或者視圖之間丶控制器之間的通信,不是從后臺請求的,這個要搞清楚。
和之前說的$rootScope通信效果是一樣的。
監(jiān)聽路由Angular 路由狀態(tài)發(fā)生改變時可以通過"$stateChangeStart"、"$stateChangeSuccess"、"$stateChangeError"監(jiān)聽,通過注入"$location"實現(xiàn)狀態(tài)的管理。
代碼示例如下:function run($ionicPlatform, $location, Service, $rootScope, $stateParams) { //路由監(jiān)聽事件 $rootScope.$on("$stateChangeStart", function(event, toState, toParams, fromState, fromParams) { console.log(event); //該事件的基本信息 console.log(toState); //我們可以得到當前路由的信息,比如路由名稱,url,視圖的控制器,模板路徑等等 console.log(toParams); //我們可以得到當前路由的參數(shù) console.log(fromState); //我們可以得到上一個路由的信息,比如路由名稱,url,視圖的控制器,模板路徑等等 console.log(fromParams); //我們可以得到上一個路由的參數(shù) if (toState.name == "dash") { //獲取參數(shù)之后可以調(diào)請求判斷需要渲染什么頁面,渲染不同的頁面通過 $location 實現(xiàn) if (toParams.id == 10) { //$location.path();//獲取路由地址 // $location.path("/validation").replace(); // event.preventDefault()可以阻止模板解析 } } }) // stateChangeSuccess 當模板解析完成后觸發(fā) $rootScope.$on("$stateChangeSuccess", function(event, toState, toParams, fromState, fromParams) { //code }) // $stateChangeError 當模板解析過程中發(fā)生錯誤時觸發(fā) $rootScope.$on("$stateChangeError", function(event, toState, toParams, fromState, fromParams, error) { //code }) }在頁面渲染中 可通過"$viewContentLoading"和 "$viewContentLoaded"監(jiān)聽頁面渲染狀態(tài):渲染開始和渲染結(jié)束。(在控制器中添加以下代碼實現(xiàn)監(jiān)聽)
// $viewContentLoading- 當視圖開始加載,DOM渲染完成之前觸發(fā),該事件將在$scope鏈上廣播此事件。 $scope.$watch("$viewContentLoading",function(event, viewConfig){ alert("模板加載完成前"); }); //$viewContentLoaded- 當視圖加載完成,DOM渲染完成之后觸發(fā),視圖所在的$scope發(fā)出該事件。 $scope.$watch("$viewContentLoaded",function(event){ alert("模板加載完成后"); });我們可以用這些監(jiān)聽事件來判斷用戶傳參,權(quán)限判定等等。
工作原理我們了解一下uiRouter路由的工作原理
路由的創(chuàng)建
大致可以理解為:一個 查找匹配 的過程。就是將 hash值 (#xxx)與一系列的 "路由規(guī)則" 進行查找匹配,匹配出一個符合條件的規(guī)則,然后根據(jù)這個規(guī)則,進行數(shù)據(jù)的獲取,以及頁面的渲染。
我們分兩步學(xué)習(xí)我們通過調(diào)用 $stateProvider.state(...) 方法,創(chuàng)建了一個簡單路由規(guī)則(詳情看上文)
當我們反問http://...index.html#/dash.html的時候,這個路由規(guī)則被匹配到,對應(yīng)的模板會被填到某個 [ui-view] 中。
它做了些什么呢。首先,創(chuàng)建并存儲一個state對象,里面包含著該路由規(guī)則的所有配置信息。
然后,調(diào)用 $urlRouterProvider.when(...) 方法(上文說過ui-router是基于ngRouter),進行路由的 注冊 (之前是路由的創(chuàng)建),代碼里是這樣寫的:$urlRouterProvider.when(state.url, ["$match", "$stateParams", function ($match, $stateParams) { // 判斷是否是同一個state || 當前匹配參數(shù)是否相同 if ($state.$current.navigable != state || !equalForKeys($match, $stateParams)) { $state.transitionTo(state, $match, { inherit: true, location: false }); } }]);當 hash值 與 state.url 相匹配時,就執(zhí)行后面那段回調(diào),回調(diào)函數(shù)里面進行了兩個條件判斷之后,決定是否需要跳轉(zhuǎn)到該state。
至于說為什么說 "跳轉(zhuǎn)到該state,而不是該url"? 其實 ui.router是基于state(狀態(tài))的,而不是url,之前就說過,路由存在著明確的 父子關(guān)系 ,每一個路由可以理解為一個state,當程序匹配到某一個子路由時,我們就認為這個子路由state被激活,同時,它對應(yīng)的父路由state也將被激活。我們還可以手動的激活某一個state,就像上面寫的那樣, $state.transitionTo(state, ...) ,這樣的話,它的父state會被激活(如果還沒有激活的話),它的子state會被銷毀(如果已經(jīng)激活的話)。
接著回到路由注冊,路由注冊調(diào)用了 $urlRouterProvider.when(...) 方法,它創(chuàng)建了一個rule,并存儲在rules集合里面,之后的,每次hash值變化,路由重新查找匹配都是通過遍歷這個 rules 集合進行的。
路由的查找匹配當路由的創(chuàng)建和注冊,接下來,就是路由的查找匹配了。這是一個復(fù)雜而又繁瑣的過程,繞到我都有點不想說。
angular 在剛開始的$digest(解析,臟查詢,能做的事情很多)時, $rootScope 會觸發(fā) $locationChangeSuccess 事件(angular在每次瀏覽器hash change的時候也會觸發(fā) $locationChangeSuccess事件)ui.router 監(jiān)聽了 $locationChangeSuccess 事件,于是開始通過遍歷一系列rules,進行路由查找匹配當匹配到路由后,就通過 $state.transitionTo(state,...) ,跳轉(zhuǎn)激活對應(yīng)的state最后,完成數(shù)據(jù)請求和模板的渲染
來上一段源碼function update(evt) { // ...省略 function check(rule) { var handled = rule($injector, $location); // handled可以是返回: // 1. 新的的url,用于重定向 // 2. false,不匹配 // 3. true,匹配 if (!handled) return false; if (isString(handled)) $location.replace().url(handled); return true; } var n = rules.length, i; // 渲染遍歷rules,匹配到路由,就停止循環(huán) for (i = 0; i < n; i++) { if (check(rules[i])) return; } // 如果都匹配不到路由,使用otherwise路由(如果設(shè)置了的話) if (otherwise) check(otherwise); } function listen() { // 監(jiān)聽$locationChangeSuccess,開始路由的查找匹配 listener = listener || $rootScope.$on("$locationChangeSuccess", update); return listener; } if (!interceptDeferred) listen();看懂的朋友就會發(fā)現(xiàn)一個問題,每次路由變化(hash變化),由于監(jiān)聽‘$locationChangeSuccess"事件,都要進行rules的遍歷 來查找匹配路由,然后跳轉(zhuǎn)到對應(yīng)的state。我們之所以要循環(huán)遍歷rules,是因為要查找匹配到對應(yīng)的路由(state),然后跳轉(zhuǎn)過去,倘若不循環(huán),也是能直接找到對應(yīng)的state。在用ui.router在創(chuàng)建路由時:會實例化一個對應(yīng)的state對象,并存儲起來(states集合里面)。每一個state對象都有一個state.name進行唯一標識(如:"dash")。這時候就體現(xiàn)出 ui-sref指令的大作用了。
通過ui-sref跳轉(zhuǎn)到dash.html當點擊這個a標簽時,會直接跳轉(zhuǎn)到dash.html,而并不需要循環(huán)遍歷rules。這個元素折行了一個方法,還是直接看代碼
element.bind("click", function(e) { // .. var transition = $timeout(function() { // 手動跳轉(zhuǎn)到指定的state $state.go(ref.state, params, options); }); });ui-sref="dash"指令會給對應(yīng)的dom添加 click事件 ,然后根據(jù)dash(state.name),直接跳轉(zhuǎn)到對應(yīng)的state。
跳轉(zhuǎn)到對應(yīng)的state之后,ui.router會做一個善后處理,就是改變hash,此時就會觸發(fā)’$locationChangeSuccess"事件,然后執(zhí)行回調(diào),但是在回調(diào)中可以通過一個判斷代碼規(guī)避循環(huán)rules。
代碼段:function update(evt) { var ignoreUpdate = lastPushedUrl && $location.url() === lastPushedUrl; // 手動調(diào)用$state.go(...)時,直接return避免下面的循環(huán) if (ignoreUpdate) return true; }所以我們在使用中可通過ui-serf來實現(xiàn)路由,達到視圖切換,或者在controller中調(diào)用 $state.go(....)來實現(xiàn)。
結(jié)語路由介紹的就這么多,但是任然要仔細逐行閱讀。也有一部分拓展,項目中沒有實際用到,但是也算是給優(yōu)化做一些思路。與大家共勉。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/92713.html
相關(guān)文章
AngularJS簡述
流行框架 簡介 angularjs是一款非常優(yōu)秀的前端高級JS框架,由谷歌團隊開發(fā)維護,能夠快速構(gòu)建單頁web應(yīng)用,化繁為簡 無論是angularjs還是jQuery都是用原生JS封裝的 庫:對代碼進行封裝,調(diào)用封裝的方法,簡化操作 傳統(tǒng)方式是用get方式獲取元素,然后點方法 jQuery庫實現(xiàn)了對獲取方式的封裝,對方法的封裝 框架:提供代碼書寫規(guī)則,按照規(guī)則去寫代碼,框架會幫我們實現(xiàn)響應(yīng)的功能...
Vue面試中,經(jīng)常會被問到的面試題/Vue知識點整理
摘要:可以在該鉤子中進一步地更改狀態(tài),不會觸發(fā)附加的重渲染過程。我工作中只用到,對和不怎么熟與的區(qū)別相同點都支持指令內(nèi)置指令和自定義指令都支持過濾器內(nèi)置過濾器和自定義過濾器都支持雙向數(shù)據(jù)綁定都不支持低端瀏覽器。 看看面試題,只是為了查漏補缺,看看自己那些方面還不懂。切記不要以為背了面試題,就萬事大吉了,最好是理解背后的原理,這樣面試的時候才能侃侃而談。不然,稍微有水平的面試官一看就能看出,是...
angularjs+springMvc學(xué)習(xí)筆記
摘要:回調(diào)說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)和,下面的方法請求成功執(zhí)行,失敗執(zhí)行異步異步的原理我看了網(wǎng)上的一些博客和例子,大都以定時任務(wù)為例子說明,但具體的原理我還是不太 回調(diào) 說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)success和error,下...
angularjs+springMvc學(xué)習(xí)筆記
摘要:回調(diào)說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)和,下面的方法請求成功執(zhí)行,失敗執(zhí)行異步異步的原理我看了網(wǎng)上的一些博客和例子,大都以定時任務(wù)為例子說明,但具體的原理我還是不太 回調(diào) 說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)success和error,下...
發(fā)表評論
0條評論
閱讀 1364·2019-08-30 15:44
閱讀 2108·2019-08-30 11:04
閱讀 528·2019-08-29 15:17
閱讀 2547·2019-08-26 12:12
閱讀 3138·2019-08-23 18:09
閱讀 927·2019-08-23 15:37
閱讀 1529·2019-08-23 14:43
閱讀 2930·2019-08-23 13:13