国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

詳解使用angularjs的ng-options時(shí)如何設(shè)置默認(rèn)值(初始值)

2019-11-19 16:02:55
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

這兩天我用ng-options過(guò)程中遇到的初始值為空白的問(wèn)題,記得去年就遇到過(guò),怎么解決的忘記了,費(fèi)了一陣子功夫之后解決了,想記下來(lái),方便遇到同樣問(wèn)題的小伙伴當(dāng)然還有自己。

1.場(chǎng)景:

就是做一個(gè)查詢(xún)列表的彈窗,其中有一個(gè)條件需要用到下拉菜單,數(shù)據(jù)是用過(guò)ajax傳遞過(guò)去的。

2.實(shí)現(xiàn):

a.html:

<select ng-model="myselect" ng-options="o for o in options"></select> 

b.js:

var url = 'xxxxxx';//該url只是舉例,具體的代碼要寫(xiě)可用的請(qǐng)求地址。 $http.post(url).        success(functoin(data){         $sope.options=data; //賦值給ng-options          }); 

我當(dāng)時(shí)以為,html寫(xiě)好,動(dòng)態(tài)數(shù)據(jù)傳遞給ng-options,這樣下拉菜單就可以用了。運(yùn)行之后也大致正常,只是下拉菜單是空白的,點(diǎn)擊之后出現(xiàn)后臺(tái)傳遞的數(shù)據(jù),就多了第一個(gè)的空白項(xiàng),點(diǎn)擊彈出所有的下拉選項(xiàng),選擇要選的選項(xiàng)之后,空白項(xiàng)就又消失了。

查看瀏覽器中加載好的html發(fā)現(xiàn)<select>標(biāo)簽中多了一個(gè)非后臺(tái)傳遞的option:

 <select ng-model="myselect" ng-options="o for o in options"> <option value="?"></option> <option value="0">--請(qǐng)選擇--</option> . . </select> 

有點(diǎn)諷刺的是,我去年開(kāi)發(fā)的一個(gè)頁(yè)面中的下拉菜單就遇到過(guò)這個(gè)問(wèn)題,當(dāng)時(shí)費(fèi)了老大功夫才解決,但是怎么解決的竟然忘記了,沒(méi)辦法,我又試了一通ng-init都不行,依然出現(xiàn)空白的選擇首先展示出來(lái)。

想了一下這個(gè)value="?" 有時(shí)候是“undefind”應(yīng)該是ng-model="myselect"的初始值,當(dāng)后端數(shù)據(jù)傳遞過(guò)來(lái)賦值給options之后(即:$sope.options=data;),angularjs一定是沒(méi)有覆蓋select的原始o(jì)ption,即$scope.myselect=undefind,而是在這個(gè)option基礎(chǔ)上加上了后端傳遞過(guò)來(lái)的data數(shù)據(jù),從而導(dǎo)致頁(yè)面上下拉菜單中多出一個(gè)空白的下拉選項(xiàng)。

按照這個(gè)思路,又查了一下stackoverflow中的一些說(shuō)法,我將js改成從為options賦值時(shí)就初始化myselect:

var url = 'xxxxxx';//該url只是舉例,具體的代碼要寫(xiě)可用的請(qǐng)求地址。 $http.post(url).        success(functoin(data){         $scope.options=data; //賦值給ng-options          $scope.myselect = $scope.options[0];         }); 

這樣,問(wèn)題真的解決了。 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 儋州市| 嵊泗县| 张掖市| 原阳县| 镇雄县| 绥德县| 平泉县| 济阳县| 澄城县| 祁阳县| 斗六市| 宁化县| 澄迈县| 嘉兴市| 泽库县| 昌都县| 盐津县| 弋阳县| 峨边| 化州市| 洪泽县| 永济市| 应用必备| 高雄县| 报价| 滨海县| 林甸县| 德阳市| 娱乐| 新营市| 泾川县| 桂阳县| 绥棱县| 綦江县| 巴塘县| 常熟市| 佛山市| 新龙县| 息烽县| 宁南县| 关岭|