欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

angular如何實(shí)現(xiàn)一個(gè)列表的選擇全選交互組件-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)angular如何實(shí)現(xiàn)一個(gè)列表的選擇全選交互組件的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

網(wǎng)站的建設(shè)成都創(chuàng)新互聯(lián)公司專注網(wǎng)站定制,經(jīng)驗(yàn)豐富,不做模板,主營(yíng)網(wǎng)站定制開發(fā).小程序定制開發(fā),H5頁(yè)面制作!給你煥然一新的設(shè)計(jì)體驗(yàn)!已為服務(wù)器租用等企業(yè)提供專業(yè)服務(wù)。

需求分析

  1. 實(shí)現(xiàn)單選;

  2. 實(shí)現(xiàn)全選;

  3. 可以設(shè)置允許多選還是單選。如果多選,有大選擇數(shù)限制;

  4. 實(shí)現(xiàn)跨頁(yè)選擇。這里的跨頁(yè)選擇指的是切換到下一頁(yè)后,還能記住上一頁(yè)的選擇。以前我們遇到的選擇往往都是只記住當(dāng)前頁(yè),一旦刷新就清空了。這是一個(gè)不同的地方;

  5. 要求自己定義UI及交互觸發(fā);

設(shè)計(jì)思路

  1. 這里其實(shí)是相同的地方就是選擇的交互邏輯,所以重點(diǎn)考慮如何封裝這個(gè)邏輯。這里的交互邏輯主要是: 2. 點(diǎn)擊全選; 3. 點(diǎn)擊列表item的選擇切換。如果是單選,要清空之前的選擇;如果是多選,要檢查是否超過(guò)大選擇限制;

  2. 再來(lái)看一下應(yīng)用場(chǎng)景相同的地方。我們將設(shè)定上下文肯定有一個(gè)list數(shù)組,一個(gè)已選數(shù)組。 因此,我們得到如下的指令。

moSelect指令

封裝全選邏輯的指令。適應(yīng)場(chǎng)景:

  1. 有一個(gè)list集合;

  2. 每一個(gè)item是一個(gè)對(duì)象;

  3. 跨頁(yè)選擇;

使用方式

<table mo-select="list" select-all-name="isSelectedAll" item-name="item" item-select-name="select" selected-list-name="selectedList" init-selected-list="initSelectedList" allow-multiple-select="false" select-count-limit="2" item-equal-func="itemEqual">
            <thead>
              <tr>
                <th><input type="checkbox" ng-checked="isSelectedAll" mo-select-all></th>
                <th>商戶名稱</th>
                <th>電話</th>
                <th>地點(diǎn)</th>
                <th>更新時(shí)間</th>
                <th>播放</th>
              </tr>
            </thead>
            <tbody>
              <tr ng-repeat="item in list" mo-select-single >
                <td>
                   <input type="checkbox" ng-checked="item.select" mo-select-single1 > 
                </td>
                <td>{{item.name}}</td>
                <td>{{item.tel}}</td>
                <td>{{item.addr}}</td>
                <td>{{item.updateTime|msDateFormat:'YYYY-MM-DD'}}</td>
                <td>
                  <div audio-playable="item.url" play-trigger=".audio-play" pause-trigger=".audio-pause">
                    <button class="btn btn-primary audio-play" ng-show="!audioInfo.playing" >播放</button>
                    <button class="btn btn-primary audio-pause" ng-show="audioInfo.playing" >暫停</button>
                  </div>
                </td>
              </tr>
            </tbody>
          </table>

說(shuō)明:

1、主要通過(guò)三個(gè)指令實(shí)現(xiàn)全選相關(guān)的代碼封裝;

2、mo-select 是容器指令,定義了全選,以及單選 item 的方法,定義在列表容器dom上;

  1. mo-select的 值是scope的 list 對(duì)象,與 ng-repeat 里的 items 一致;

  2. item-name :告訴指令,每一項(xiàng)的對(duì)象名,指令會(huì)通過(guò)該名稱在每一項(xiàng)的scope里查找。與ng-repeat里的 item 一致;

  3. select-all-name :全選的狀態(tài)變量。默認(rèn): isSelectedAll

  4. item-select-name : 記錄的每一項(xiàng)對(duì)象是否選中的變量名,將會(huì)存儲(chǔ)在 item 對(duì)象上,為了避免與現(xiàn)有業(yè)務(wù)字段重合,可以配置,也可以不配置,默認(rèn): select ;

  5. selected-list-name :已選對(duì)象列表的變量名。默認(rèn): selectedList ;

  6. init-selected-list :初始化選擇對(duì)象列表。該變量只用于初始化,類似 vue 組件里的 prop 屬性;

  7. allow-multiple-select :是否允許多選;

  8. select-count-limit :如果允許多選,最多可以選擇多少個(gè)。如果不傳,則無(wú)限;

  9. item-equal-func :對(duì)象判等函數(shù),用于封裝業(yè)務(wù)對(duì)象自己的判等原則。比如:有些場(chǎng)景是根據(jù)id,有些是根據(jù)其他業(yè)務(wù)邏輯。如果不傳,默認(rèn)根據(jù)對(duì)象的id屬性;

3、mo-select-all 全選指令。定義在全選 dom 上,一版是一個(gè) input checkbox 。其值表示在當(dāng)前scope保存的是否全選的變量名;
4、mo-select-single 單選指令。 定義在每一項(xiàng) dom 上??梢杂袃蓚€(gè)地方:

  1. 定義在自己的 input chebox 上

  2. 定義在 input 的容器上。類似 tr ,實(shí)現(xiàn)點(diǎn)擊整行選中。也可以定義在某個(gè)單個(gè)元素上。

如果要獲取已選項(xiàng),直接在當(dāng)前scope獲取 selected-list-name 指定的變量名即可。

使用步驟:

  1. 在容器定義 mo-select ,根據(jù)實(shí)際需求,配置相關(guān)參數(shù)。必須: mo-select , item-name ;

  2. 在需要全選的按鈕 dom 上添加 mo-select-all 指令,不需要配置任何參數(shù);

  3. 在 ng-repeat 的單項(xiàng)模板里,在需要添加單選交互的 dom 上添加 mo-select-single 指令,不需要配置任何參數(shù);

  4. 完成配置。

注意事項(xiàng)

  1. mo-select 的值一定要和ng-repeat的 items 一致;

  2. item-name 的值一定要和ng-repeat的 item 一致;

總結(jié)

這樣的指令在我們的業(yè)務(wù)開發(fā)中使用還是很靈活的??赡芸雌饋?lái)配置項(xiàng)有點(diǎn)麻煩,其實(shí)大多數(shù)都是可以采用默認(rèn)值的。我們看看它的不同表現(xiàn)形式:

angular如何實(shí)現(xiàn)一個(gè)列表的選擇全選交互組件

angular如何實(shí)現(xiàn)一個(gè)列表的選擇全選交互組件

感謝各位的閱讀!關(guān)于“angular如何實(shí)現(xiàn)一個(gè)列表的選擇全選交互組件”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

本文題目:angular如何實(shí)現(xiàn)一個(gè)列表的選擇全選交互組件-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://chinadenli.net/article44/dgjihe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、微信小程序、網(wǎng)頁(yè)設(shè)計(jì)公司、網(wǎng)站策劃、網(wǎng)站設(shè)計(jì)、搜索引擎優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司