<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                本篇文章我們封裝一個卡片組件,不使用elementui中的卡片樣式而仿照其邏輯制作,我們可以更深入理解并易于修改出自己想要的樣式。 1.制作出我們想要的框架 ``` <div class="card p-3 bg-white mt-3"> <div class="card-header d-flex"> <div class="fs-xxl flex-1 px-2">最新文章</div> <span class="iconfont icon-more text-gray"></span> </div> <div class="mt-3 mb-1 px-2"> <div style="width: 100%;height:1px;" class="bg-gray2"></div> </div> <div class="card-body"> <div class="nav nav-inverse d-flex jc-between px-2 pt-3 pb-2"> <div class="nav-item"> <div class="nav-link active" active-class="active">最熱</div> </div> <div class="nav-item"> <div class="nav-link" active-class="active">最新</div> </div> <div class="nav-item"> <div class="nav-link" active-class="active">學習</div> </div> <div class="nav-item"> <div class="nav-link" active-class="active">推薦</div> </div> <div class="nav-item"> <div class="nav-link" active-class="active">作品</div> </div> </div> <swiper> <swiper-slide v-for="m in 5" :key="m"> <div class="py-2 px-2 d-flex jc-around" v-for="n in 5" :key="n"> <span class="text-primary">[最熱]</span> <span class="px-2 text-gray">|</span> <span class="ellipsis">這條新聞好多人看啊啊啊啊啊啊啊啊啊啊啊</span> <span class="text-gray">2021-07-13</span> </div> </swiper-slide> </swiper> </div> </div> ``` ![](https://img.kancloud.cn/c8/85/c885dbc062a73777a4586334dbe60275_1346x1003.png) 2.制作卡片組件 卡片組件的制作,最終要實現卡片標簽,標簽中有標簽屬性。其中屬性為組件中的變量。 (1)將剛才制作的通用模板card放入Card.vue ![](https://img.kancloud.cn/eb/86/eb8633df59c6a5b93f18755f6ea03d3f_1004x1003.png) (2)在主文件main.js中引入Card.vue組件 ``` // 卡片組件 import Card from './components/Card.vue' Vue.component('m-card', Card) ``` ![](https://img.kancloud.cn/23/8a/238aba6c2b300cf0d2a4b06785c4906c_1250x1003.png) 此時組件設置成功,因為此card是手機端,故設置標簽為m-card。 (3)在Home.vue使用Card組件 ``` <m-card></m-card> ``` ![](https://img.kancloud.cn/cb/00/cb00afa91be81c3d19cc73113302f853_1250x1003.png) 此時就將組件顯示在頁面中了: ![](https://img.kancloud.cn/22/2a/222a8f43d573deaad7f9d2d9720b2aae_375x667.png) 3.優化卡片組件 此時Card.vue已經成為組件,使用m-card標簽就可以使用,但組件的作用是復用性,所以我們要將組件標簽的屬性做出,同時使用vue的slot標簽進行其內容的填充(往下看就明白了)。 (1)將組件中非固定內容取出,也就是下圖所指部分: ![](https://img.kancloud.cn/b8/1e/b81e16ce76b892fb0ab51981c53c490a_374x258.png) 同時用slot標簽代替: ![](https://img.kancloud.cn/e0/3b/e03b0d7e9583c1e4f217f3b5ee0a0445_1250x1003.png) 然后將取出的內容放在m-card標簽中: ![](https://img.kancloud.cn/c8/6c/c86ca53a88410e145b83e4a80e6a1701_1250x1003.png) 此時內容部分依舊顯示: ![](https://img.kancloud.cn/72/27/7227b96a423d016b9c1649a0765c8f11_375x302.png) (2)為m-card標簽添加屬性 就如 標簽一樣,其中包括了style屬性、class屬性等等,我們要在標簽上添加屬性,從而更改組建的標題和圖標等內容。 回到Card.vue: 添加prop屬性 ``` export default { // 設置屬性接收 props: { // 其中type表示屬性類型,required: true表示必填 可添加默認值default: '卡片組件' title: {type: String, required: true}, icon: {type: String, required: true}, }, } ``` ![](https://img.kancloud.cn/8b/c7/8bc70fbe15b46c1fbc2c2545813c7812_1250x646.png) 同時,將上方對應的標題和圖標進行動態綁定。由于之前沒有對標題前加iconfont,現在加一下: ![](https://img.kancloud.cn/fd/8f/fd8f17dc7ffc03eb26e0e8e7abbb4961_1250x644.png) 保存后,此時頁面中卡片組件沒有標題及圖標內容: ![](https://img.kancloud.cn/8d/39/8d390853e1f92608205ae2cf112b22aa_371x252.png) 現在我們對m-card組件添加屬性: ![](https://img.kancloud.cn/e0/75/e0757cc8d93f6bdf03982f46385d8148_1250x1003.png) 頁面顯示標題和圖標: ![](https://img.kancloud.cn/28/8d/288d1aa712f88dbd6819f40dbf9494ff_373x252.png) 成功,再添加一個標簽: ![](https://img.kancloud.cn/4c/8a/4c8a480b8b6b3122ba36a21bdb431e0b_1250x1003.png) 成功,效果還行: ![](https://img.kancloud.cn/2e/c4/2ec4955862ff84674ea41398d8d1ca4a_391x367.png) 4.總結 卡片組件,就是封裝了一個外部輪廓到.vue組件文件中,然后使用component將其當作標簽使用。定義屬性的目的是將外部的值傳入到.vue組件中的變量上,從而達到標簽中屬性的效果。 5.延申 在目前封裝的卡片組件來看,我們動態綁定的就只有title和icon兩項,而其中不管是輪播還是內部數據都需要我們詳細寫: ![](https://img.kancloud.cn/6e/5f/6e5fcf7f02abb1152be5d095788c2a2e_370x248.png) 如果我們就可以在m-card外再套一層組件m-list-card來動態填寫其輪播框架和內容,就不需要每次詳細做一個swiper來顯示內容。在不需要輪播的卡片中,我們就只用m-card即可。 創建ListCard.vue組件并引用: 將m-card標簽內容全部放入ListCard.vue中,并且引用ListCard.vue以m-list-card標簽來使用: ![](https://img.kancloud.cn/65/b7/65b7b38a3c9e867099614fa60c668234_1250x1003.png) Home.vue添加m-list-card標簽: ![](https://img.kancloud.cn/12/47/1247737cd617e8b8944a71f67658e66e_481x233.png) 頁面依舊會呈現: ![](https://img.kancloud.cn/57/7e/577ee9e9c8319f081fe59ff43e35496e_367x434.png) 此時我們查看外部哪些內容需要動態設置: ![](https://img.kancloud.cn/80/78/80780c1fb196a12e81bdae2875d255a4_468x305.png) 所以我們需要動態綁定的數據增加了一個分類,categories,以數組形式展現: ![](https://img.kancloud.cn/e6/63/e663c0ff67417c8b72989f84177c8d3c_1260x685.png) 同時添加m-list-card外部傳值: ``` <m-list-card icon="list" title="相關文章" :categories="articleData"></m-list-card> ``` ![](https://img.kancloud.cn/0d/ae/0dae5aad078ce80d0617695d907bfe2a_1094x897.png) 下方js為categoryData手動添加內容,模仿后臺調用的數據json格式: ![](https://img.kancloud.cn/07/c3/07c310dee388e7c1a56bbaaf471272e5_1260x897.png) 將我們之前分的五塊分類內容寫出來,注意此時categoryData為數組格式: ![](https://img.kancloud.cn/5e/ae/5eaef75defaecd46ec716ee83388f7e7_427x530.png) 最后,將ListCard.vue中的m-card標簽內部需要動態傳值的內容替換: ![](https://img.kancloud.cn/7f/aa/7faa503983686e832de1916f0c4717fa_1268x884.png) 此時,active功能暫時刪除,待數據完成綁定后我們再給其綁定動態的active。現在觀察頁面: ![](https://img.kancloud.cn/48/26/482674ca177df54382d1b3c9c9ff3bad_309x287.png) 五個分類的標題已經呈現,現在我們需要將每個分類中的文章通過slot標簽引入: ![](https://img.kancloud.cn/29/1b/291b00ec8e096177f7477f467e1794e7_620x650.png) 外部使用category數據的方式: ![](https://img.kancloud.cn/09/4c/094c5491c0116b760610d506479960b6_912x1006.png) 此時頁面正常顯示了: ![](https://img.kancloud.cn/f5/d3/f5d30be65a820764285e5aa710e36198_358x405.png) 最后,為switer動態添加active: ![](https://img.kancloud.cn/e9/33/e93317ab781b8cb91acb042e8977007b_916x982.png) 此時分類標題欄已經可以顯示active效果: ![](https://img.kancloud.cn/44/e0/44e0cc0b8df25d2ac8655fdc729b3322_364x199.png) 下一步,關聯分類下邊的內容,與標題active同步: (1)首先給swiper掛載一個名字,方便分類標題找到其對應的swiper: ![](https://img.kancloud.cn/84/1b/841b08a82a2265d308e918d182c47f48_699x742.png) (2)為swiper添加函數,在切換swiper時同時切換swiper的索引值,將其索引值賦值給active: ![](https://img.kancloud.cn/24/3b/243bd165b17533f03288f936c4ce20c4_599x64.png) (3)最后,利用swiper的slideTo方法,在點擊分類標題時將分類標題的索引發送給swiper: ![](https://img.kancloud.cn/d7/35/d735b3ecce838c52b2f0cf44be60873b_663x258.png) 此時當點擊分類標題發送索引到swiper時,swiper接收索引并賦值給active,active變化,則分類標題的樣式變化。 (4)如果第一次進入頁面,active沒有值,此時沒有分類標題: ![](https://img.kancloud.cn/50/46/5046aeaebd06295738f2f0c49158d277_363x200.png) 所以要給active一個初始值0,使其第一次進入頁面時就可以效果: ![](https://img.kancloud.cn/22/3f/223f6a207fe987f9bc5ad93db80102d2_167x100.png) ![](https://img.kancloud.cn/f3/0b/f30bea474a30d44c0fc90aa59c0832a4_369x212.png) 下節內容我們調用后臺數據接口,獲取文章數據到頁面中。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看