• <abbr id="chdyf"></abbr>
    <ruby id="chdyf"><acronym id="chdyf"><meter id="chdyf"></meter></acronym></ruby>
    <bdo id="chdyf"></bdo>
    <dfn id="chdyf"><menu id="chdyf"></menu></dfn>
    1. <menuitem id="chdyf"></menuitem><strong id="chdyf"><menu id="chdyf"></menu></strong>

      <rt id="chdyf"><menu id="chdyf"></menu></rt>
      成人小说一区二区三区,伊人精品成人久久综合全集观看,久久HEZYO色综合,中文字幕精品人妻熟女,影音先锋成人网站,我要看免费一级毛片,中国女人做爰A片,中文字幕av久久爽Av

      CSS偽類:empty讓我眼前一亮

      2020-11-4    前端達人

      最近看過我文章的都知道:我最近在負責一個微信小程序的項目,在其中遇到了很多有趣的事和一些“奇思妙想”。本文的背景就是某天早上我看著wxml文件中一堆wx:if/elsehidden突然很煩躁,先不說wx:if導致的性能問題,就是標簽上也是冗雜的。


      接著上一篇文章【微信小程序自定義組件庫yPicker組件分析及省市區(qū)三級聯(lián)動實現(xiàn)】,在其中我分析了這么一個例子 —— 省市區(qū)三級聯(lián)動的自定義實現(xiàn),在其中有詳細代碼這里就不多說,說說如何調用:

      我當時是這么想的:一方面出于“不在JavaScript里寫太多東西”的考慮,另一方面,由于省、市、區(qū)我是分別用三個變量來實現(xiàn)的,所以JavaScript里就關注這三個變量,比如之間的空格或其它東西都拿到wxml文件里。就像這樣:

      <view class="departments location" bindtap="fixedshow"> <view class="depart_title">所在位置</view> <view wx:if="{{provinces&&citys&&areas}}" class="placeholder depart_content">{{provinces}} {{citys}} {{areas}}</view> <view class="placeholder depart_content befselect" wx:else>請選擇當前位置</view> <view class="desc">如有變動請修改后再次提交</view> </view> 
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6

      (因為調用涉及到后來改動的只有在點擊彈窗里的“確認”按鈕時在事件中將那三個變量分別賦給這段代碼中出現(xiàn)的三個變量 —— 否則會只要改動不管是點取消還是確認已經發(fā)生改變了,這樣不妥!)

      其布局是這樣的:

      .departments{ width: 100%; height: 96rpx; display: flex; align-items: center; font-size: 36rpx; font-weight: 347; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; } .location{ position: relative; border-bottom: 1rpx solid rgba(0,0,0,.009); display: flex; align-items: flex-start; padding-top: 20rpx; } .desc{ position: absolute; right: 19rpx; bottom: 4rpx; color: rgb(63,142,255); font-size: 23rpx; } .departments .depart_title{ width: 20%; } .departments .depart_content{ margin-left: 10%; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; } .departments .placeholder{ width: 69%; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; } 
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41

      location


      在決定了要替換這里的wx:if以后,你首先要想:用什么替換?
      wx:if作用是判斷“是否存在”,如果不存在(條件不滿足)就切換到wx:else或是wx:elif的邏輯里!

      OK,想到這里,你應該能想到一個css偽類::empty !它的作用和我們想要的效果一樣:判斷如果元素(內容)為空的話…
      我迅速對代碼做了改動:

      <view class="departments location" bindtap="fixedshow"> <view class="depart_title">所在位置</view> <view class="placeholder depart_content">{{provinces}} {{citys}} {{areas}}</view> <view class="desc">如有變動請修改后再次提交</view> </view> 
      
      • 1
      • 2
      • 3
      • 4
      • 5

      然后在class - depart_content上加了這個偽類:

      .placeholder:empty::before{ content: "請選擇當前位置"; color: rgba(0,0,0,.6); } 
      
      • 1
      • 2
      • 3
      • 4

      wx
      一片空白!

      經過查閱資料::empty偽類表示如果標簽內容為空,那么內容區(qū)域如果帶有空格,也是不會被匹配到的!

      在寫標簽時一定要注意這一點:標簽內是否有空格或換行!(換行常常被解析為一個空格)
      遇到非單標簽一定注意閉合標簽!

      最后解決辦法是:在js中將三個變量用空格相連接,再渲染到頁面上即可!
      wx-position
      (其實這里是一個自定義的選擇器,而自動定位就是往高德地圖發(fā)送了請求獲取到省市區(qū)字段而已,代碼就不寫了。。。)


      到這里我們會發(fā)現(xiàn)一個事:上面我們不僅用了empty偽類,還用了before偽元素!

      其實這一點很平常 —— 畢竟只有empty是添加不了內容的(似乎縱觀css,只有before和after這樣偽元素可以向頁面中添加內容,不管是文字還是圖片之類的)

      我認為更應該關注到的是兩個地方:

      1. 偽元素中沒有用position定位!一般來說對一個(存在內容的)元素來說,為其設置“前置”(before)/“后置”(after)樣式都需要定位:規(guī)定其顯示的地方。不然大概率偽元素中的文字是顯示不出來的,通過本文的empty可以猜測:他被原本存在的內容覆蓋住了。
      2. 從第一點可以得出::before 和 :after 偽元素向標簽內插入內容、圖形,并不會影響empty偽類的匹配!

      這個特性實用的一批。


      由上,可見此偽類最大的用處就是“字段缺失提示”!這是非常實用的。而且把這項任務交給CSS也可以減輕許多“(布局)負擔”、體驗更好、維護起來也更方便!

      比如:我在項目優(yōu)化時就將所有有請求的字段都加上了統(tǒng)一類名:

      .ym-empty:empty::before{ content: "暫無數(shù)據(jù),請重試", display: block; text-align: center; color: rgba(0,0,0,.6); /** 其它定位、字體更改操作 */ }


      作者:,轉載


      日歷

      鏈接

      個人資料

      藍藍設計的小編 http://www.wtxcl.cn

      存檔

      主站蜘蛛池模板: 狼群社区视频WWW| 狠狠狠色丁香婷婷综合久久俺| 91视频在线观看视频| 山东省| 远安县| 免费无码AV片在线观看中文| 天堂无码人妻精品一区二区三区 | 亚洲影音先锋| 尤物视频成人在线视频| 久久99精品国产99久久6不卡| 亚洲蜜臀av乱码久久| 成人视频网| AV一区二区三区| 中文字幕的av| 久久影音先锋| 欧美自拍另类欧美综合图区| 亚洲第一福利导航| 浪荡干片网在线观看| 九九国产| 亚洲a级| av中文在线| 亚洲AV无码专区首页第一页 | jlzz大jlzz大全免费| 亚洲熟女精品中文字幕m| 91免费| 精品麻豆一区二区三区乱码| 国产精品久久九九99九九99| 3P在线观看视频| 狠狠干视频网站| 青田县| 3d动漫精品啪啪一区二区下载| 五月丁香伊人| 99色区| 综合AV| 亚洲精品在线第一页| 天堂偷拍| 中文字幕一区二区三区av| 久久久久香蕉国产线看观看伊| 曰的好深好爽免费视频网站| 国产精品1区| 女生洗鸡鸡喷尿的视频无马赛克?舒坦直叫的骚货视频?亚洲着九九九视频影院 |