मैं निम्नलिखित करने की कोशिश की, लेकिन यह काम नहीं करता है:स्कैस sass में * :: चयन {} कैसे लिखें?
* {
&::selection { text-decoration: underline; }
}
मैं निम्नलिखित करने की कोशिश की, लेकिन यह काम नहीं करता है:स्कैस sass में * :: चयन {} कैसे लिखें?
* {
&::selection { text-decoration: underline; }
}
::selection
छद्म तत्व draft spec में अभी भी था, text-decoration
अनुमति शैली संपत्ति में से एक के रूप में वर्णित नहीं किया गया है। यह देखते हुए कि ब्राउज़र इसे किसी भी तरह कार्यान्वित करते हैं, उन्हें उस दस्तावेज़ के अनुसार नियमों का पालन करना चाहिए, इस तरह text-decoration
को अस्वीकार करना।
उस ने कहा, आपके चयनकर्ता के साथ कुछ भी गलत नहीं है, हालांकि यह ध्यान देने योग्य है कि फ़ायरफ़ॉक्स इसके बजाय विक्रेता-प्रीफ़िक्स्ड संस्करण ::-moz-selection
का उपयोग करता है। क्रोम, सफारी और ओपेरा के साथ, उस ब्राउज़र का समर्थन करने के लिए आपको नियम दोहराना होगा (जानकारी के लिए this answer देखें)।
तो एससीएसएस में, यदि आप ऐसा करते हैं:
* {
&::-moz-selection { /* Style any selection */ }
&::selection { /* Style any selection */ }
}
आप कम करने के लिए है कि सक्षम हो सकता है mixins का उपयोग कर, लेकिन मुझे यकीन है कि अगर mixins छद्म तत्व चयनकर्ताओं के साथ काम नहीं कर रहा हूँ।
mixins छद्म तत्व चयनकर्ताओं के साथ काम, मेरा mixin) देखें:
$prefixes: ("-moz-", "");
@mixin selection($color, $background) {
@each $prefix in $prefixes {
::#{$prefix}selection {
color: $color;
background: $background;
}
}
}
कैसे उपयोग करने के लिए:
@include selection(white, black);
निश्चित रूप से
आप इसे बहुत अधिक विकल्प बना सकते हैं, लेकिन यह मेरे लिए पर्याप्त था ;)
तरह से मैं यह कर रहा है यही कारण है कि:
// define it
@mixin selection {
::-moz-selection { @content; }
::selection { @content; }
}
// use it
@include selection {
color: white;
background: black;
}
मैं मिश्रण के बजाय autoprefixer के साथ ::selection {}
का उपयोग करने की सलाह देता हूं।
::selection {
color: white;
background: black;
}
... ऐसा ही कुछ में (अपने लक्ष्य ब्राउज़रों/कॉन्फ़िगरेशन के आधार पर):
यह आपके कोड पतले और अपने दिमाग हल्का :)इस मामले में, autoprefixer इस बदल कर देगा
::-moz-selection {
color: white;
background: black;
}
::selection {
color: white;
background: black;
}
यह निश्चित रूप से पीटर के जवाब से अधिक स्वच्छ और अधिक पुन: प्रयोज्य है। उम्मीद है कि यह शीर्ष पर उगता है! – BoltClock
@VitalyBatonov यदि आपके प्रश्न का उत्तर दिया गया है, तो इसे चिह्नित करें :) – yckart
अफसोस की बात है, मुझे नहीं लगता कि ऐसा होने जा रहा है - ओपी इस उत्तर को पोस्ट करने से पहले साइट पर नहीं रहा है। आपका जवाब पहले से ही शीर्ष पर बढ़ गया है, इसलिए, कम से कम ऐसा है। – BoltClock
महान mixin, मैं जोड़कर एक नियम के अंदर काम करने के लिए बदल दिया है "&", यह मेरे लिए बेहतर काम करता है। मैंने बिना किसी उपसर्ग के नियम प्राप्त करने के लिए एक खाली उपसर्ग भी जोड़ा है।
@mixin selection($color, $background) {
$prefixes: ("-moz-", "-webkit-", "-o-", "-ms-", "");
@each $prefix in $prefixes {
&::#{$prefix}selection {
color: $color;
background: $background;
}
}
}
कम्पास के साथ आप निम्नलिखित की तरह यह कर सकता है:
@import "compass/css3/selection";
@include selection($highlightBackground, $highlightColor)
"बस किसी और की लाइब्रेरी का उपयोग करें" यह समझाता नहीं है कि कोई भी ऐसी सुविधा लिखने के बारे में कैसे जाएगा जो कि लाइब्रेरी में मौजूद नहीं है। – cimmanon
:: चयन केवल एक -moz उपसर्ग है, और यह ध्यान रखें कि यह एक गैर मानक है लायक है और नहीं किया जाना चाहिए, जांच मोज़िला डेवलपर नेटवर्क पर यह [पेज] (https://developer.mozilla.org/en-US/docs/CSS/::selection)। – Pierre
@ पीटर: अजीब बात है कि जब मैंने पहली बार इस जवाब को संपादित किया तो मैंने इसे याद किया। मैं आमतौर पर इन चीजों पर ध्यान देना चाहता हूं। (और हाँ, मुझे पता है कि आप एक ही पीटर नहीं हैं।) – BoltClock