หากคุณกำลังใช้ SASS ในโครงการของคุณฉันได้สร้างมิกซ์นี้ขึ้นมาเพื่อให้มันทำงานได้อย่างที่เราต้องการ
@mixin not($ignorList...) {
//if only a single value given
@if (length($ignorList) == 1){
//it is probably a list variable so set ignore list to the variable
$ignorList: nth($ignorList,1);
}
//set up an empty $notOutput variable
$notOutput: '';
//for each item in the list
@each $not in $ignorList {
//generate a :not([ignored_item]) segment for each item in the ignore list and put them back to back
$notOutput: $notOutput + ':not(#{$not})';
}
//output the full :not() rule including all ignored items
&#{$notOutput} {
@content;
}
}
สามารถใช้งานได้ 2 วิธี:
ตัวเลือกที่ 1: แสดงรายการที่ถูกละเว้นแบบอินไลน์
input {
/*non-ignored styling goes here*/
@include not('[type="radio"]','[type="checkbox"]'){
/*ignored styling goes here*/
}
}
ตัวเลือกที่ 2: รายการที่ถูกละเว้นในตัวแปรก่อน
$ignoredItems:
'[type="radio"]',
'[type="checkbox"]'
;
input {
/*non-ignored styling goes here*/
@include not($ignoredItems){
/*ignored styling goes here*/
}
}
เอาต์พุต CSS สำหรับตัวเลือกใดตัวเลือกหนึ่ง
input {
/*non-ignored styling goes here*/
}
input:not([type="radio"]):not([type="checkbox"]) {
/*ignored styling goes here*/
}