Comments (8)
@ahmetcaglayan I think the issue is that you're using characters which aren't recognised by the CSS parser. @
and :
are used for at-rules and pseudo elements. \
and /
aren't valid either. I tested this in plain CSS here: https://jsbin.com/mamadufolu/2/edit?html,css,output
I suggest using just the character types supported by CSS for selectors, see https://www.geeksforgeeks.org/which-characters-are-valid-in-css-class-names-selectors/
from postcss-prefix-selector.
@ahmetcaglayan I understand now, in the docs they set the prefix to:
"#single-spa-application\\:\\@org-name\\/project-name"
and then in the CSS output it will become
#single-spa-application\:\@org-name\/project-name
And because the characters are escaped, \:
, \@
, etc., it will work in plain CSS (https://jsbin.com/fequwemije/edit?html,css,output). The problem is that the SASS compiler doesn't like this kind of escaping.
I don't think I can help you. It looks like SASS doesn't like those escaped characters. I'd suggest using supported characters.
from postcss-prefix-selector.
@ahmetcaglayan I was confused by the various escaped characters but I think it should work. You had it right initially, you just needed to escape the :
character. Please try the following:
- set
prefix: "#single-spa-application\\:\\@kapital\\/dashboard"
- in SASS and CSS the selector will be prefixed with
#single-spa-application\:\@kapital\/dashboard
- The CSS selector above will match elements that have
id="single-spa-application:@kapital/dashboard
Example here: https://codepen.io/valentin/pen/KKZLWej
from postcss-prefix-selector.
@ahmetcaglayan From what I can tell you're not escaping the special characters correctly, only a single \
is needed, so the prefix option should be something like: "#single-spa-application:\@kapital\/dashboard"
.
Also I'm not sure that it's a good idea to use @
for class names, since it has special meaning, see at-rules. Maybe this is why SASS is complaining?
from postcss-prefix-selector.
When you delete the '@' sign, the situation is still the same. This time there is a problem with the '/' sign.
Even if I delete the '/' sign, the single spa's own id assignment in the html part will be like this.
from postcss-prefix-selector.
Actually it should be as you say. But it doesn't say so in the single spa document. Well, I didn't quite understand. But it automatically assigns this id for the div.
https://single-spa.js.org/docs/ecosystem-css#postcss-prefix-selector
from postcss-prefix-selector.
sass doesn't like it. I guess the single spa needs to change the prefix it uses here.
from postcss-prefix-selector.
@ahmetcaglayan Hmm, I don't see the escapes anymore, maybe you're not setting the prefix to #single-spa-application\\:\\@kapital\\/dashboard
? In the original post the escapes were there. I mean the output should be #single-spa-application\:\@kapital\/dashboard
(with the \
)
from postcss-prefix-selector.
Related Issues (20)
- postcss should be peerDependencies HOT 2
- Does not prefix styles in *.css files imported via @import HOT 2
- Request: access to root in transform callback HOT 1
- npm publish timeframe? HOT 1
- An in-range update of husky is breaking the build 🚨
- Improve documentation
- Don't prefix any unprefixable elements HOT 6
- Not working at all since upgrading to webpack 2 HOT 2
- Possible typo in README? HOT 1
- Create online plugin demos
- Whitelist option HOT 1
- Selectors starting with data attributes not working correctly HOT 2
- Update Docs with postcss-loader version 4 config HOT 1
- Publish new version
- How can I implement this with Parcel Bundler? HOT 2
- ignoreFiles/includeFiles accepting Regex? HOT 2
- Prefix css selector from third party ui-component HOT 5
- `Error: PostCSS plugin postcss-prefix-selector requires PostCSS 8.` HOT 6
- Error with pseudo-class :root HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from postcss-prefix-selector.