摘要:回調(diào)說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)和,下面的方法請求成功執(zhí)行,失敗執(zhí)行異步異步的原理我看了網(wǎng)上的一些博客和例子,大都以定時任務為例子說明,但具體的原理我還是不太
回調(diào)
說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)
例如,在下面這段代碼中,上面定義了兩個函數(shù)success和error,下面的promise.then(success,error)方法請求成功執(zhí)行success,失敗執(zhí)行error
異步的原理我看了網(wǎng)上的一些博客和例子,大都以定時任務setTimeout, setInterval為例子說明,但具體的原理我還是不太明白,我只知道js異步的執(zhí)行順序和c/c++的不同
例如,我把上面的success方法中的$scope.teachers = response.data寫到外面,即:
按照c/c++的順序,當上面promise.then()語句執(zhí)行完之后,才執(zhí)行下面的賦值語句,可js的異步處理會直接執(zhí)行下面的賦值語句,如果在控制臺輸出teachers,會顯示undefined
跨域CROS在前后臺對接時會發(fā)生跨域問題
在spring官方文檔有詳細的解決方案,如下圖
按照需求進行改寫就行了
建立數(shù)據(jù)表(后臺)在thinkphp中,我們通過navicatMysql數(shù)據(jù)庫工具建立數(shù)據(jù)表,而在spring中,則是通過新建類來建立數(shù)據(jù)表,對應關(guān)系如下
teacher類對應表名,私有屬性對應表的各個字段
然后建立接口來訪問和操作數(shù)據(jù)
這里遇到一個小問題,在定義Teacher類時,設(shè)置主鍵自增
官方推薦使用AUTO,但是由于我們的數(shù)據(jù)庫存在一些問題,只能使用IDENTITY來暫時解決
通過ui-router定制路由(前臺)ui-router的出現(xiàn)使得路由定制非常簡單易用,在安裝完ui-router后,改寫app.js
接著,在V層添加ui-view標簽就可以實現(xiàn)頁面的跳轉(zhuǎn)了
功能性開發(fā)(前臺)1.定義路由對應的控制器(ui-router)
2.初始化控制器->yoman命令->yo angular.controller user 生成位置app/scripts/controller/user.js
3.數(shù)據(jù)綁定至V層(雙向綁定)
4.功能開發(fā)
后臺
1.增加路由注解
(1)指明方法(get,post,delete,put,patch)
(2)指明地址(例如127.0.0.1:8080/Teacher)
2.有cros設(shè)置的,增加cros設(shè)置
關(guān)于第一步,按照下面的寫法改寫就行
@Autowired 自動裝置接口實例化的對象
@GetMapping使用的方法
1.第一次接觸angularjs與springMVC前后臺分離開發(fā)的模式,感受到了它比thinkphp強大的原因,非常方便團隊分工開發(fā)
2.使用注解的方式寫程序,就好像給程序注釋一樣,非常方便,而且易讀
3.yoman的自動刷新機制解放了每次寫前臺F5刷新,在寫原型時相當方便,有了angularJs的雙向綁定,就再也不會出現(xiàn)thinkphp里十幾行長的$this->assign()
4.idea編譯器強大的功能省下很多用在程序規(guī)范的精力,alt+insert生成模板相當方便,出了錯打斷點debug可以很快可以發(fā)現(xiàn)問題
5.總之,相比于thinkphp,angularJs+springMVC的開發(fā)更加規(guī)范,很容易做到代碼風格的統(tǒng)一和程序的易讀,可以將更多的精力投放到功能的設(shè)計和實現(xiàn)上來
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/97800.html
摘要:回調(diào)說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)和,下面的方法請求成功執(zhí)行,失敗執(zhí)行異步異步的原理我看了網(wǎng)上的一些博客和例子,大都以定時任務為例子說明,但具體的原理我還是不太 回調(diào) 說白了,就是把函數(shù)當參數(shù)傳給另一根函數(shù),在另一個函數(shù)執(zhí)行時調(diào)用此函數(shù)例如,在下面這段代碼中,上面定義了兩個函數(shù)success和error,下...
摘要:怎么做前后端的分離我目前的做法是將作為一種服務存在,僅需要提供接口即可,前端目前采用,調(diào)用后端,解析數(shù)據(jù),靜態(tài)頁面。采用,充當層,前后端實現(xiàn)了真正的分離,但還是有點問題的。 什么是前后端分離 對于這個問題,其實可以看看我的學習歷程,我覺得很好的體現(xiàn)了Web開發(fā)模式的演化。 石器時代:那正是本人剛學JSP的時候,寫了一個簡單的商城DEMO,所有的業(yè)務邏輯,數(shù)據(jù)庫的交互以及Javascri...
摘要:筆記這周學習安裝和配置和,為測試做準備。該軟件由創(chuàng)建,并于年首次公開發(fā)布。同名公司成立于年,以提供支持。從年月開始,的開發(fā)由贊助,而年月至年月期間,其開發(fā)由贊助。最后發(fā)現(xiàn)是因為中的中的應該為大寫將其改為及解決了此問題。 筆記 這周學習安裝和配置nginx和redis,為測試做準備。showImg(https://segmentfault.com/img/bVbpdYF?w=660&h=...
摘要:初次寫文章,請多多包涵我最近正在根據(jù)這本書從頭開始實現(xiàn)了一遍的框架。筆記目錄鏈接個人認為本書對于想了解框架源碼的讀者來說相當有用,完全值得去購買這本書書本主頁。因為是初學者,筆記里可能有一些錯誤,我也會繼續(xù)修改。 (初次寫文章,請多多包涵) 我最近正在根據(jù)《Build your own angularJS》這本書從頭開始實現(xiàn)了一遍AngularJS的框架。我把相關(guān)的源碼和我的個人學習筆...
閱讀 797·2021-08-23 09:46
閱讀 946·2019-08-30 15:44
閱讀 2604·2019-08-30 13:53
閱讀 3050·2019-08-29 12:48
閱讀 3873·2019-08-26 13:46
閱讀 1807·2019-08-26 13:36
閱讀 3520·2019-08-26 11:46
閱讀 1419·2019-08-26 10:48