Less.js: Less throws an error with the ">>>" combinator

Created on 30 Jun 2015  Â·  14Comments  Â·  Source: less/less.js

Eg,

ParseError: Unrecognised input in path\to\less\main.less on line 25, column 7:
24
25 html >>> .materialblue {
26

However, this is valid.

See:

This should be correctly passed through.

consider closing feature request needs decision

Most helpful comment

Well, they change the draft every week (see #1801, #2023). So it's not surprise.
Either way you can always use escaping:

@whatever: ~">>>"; // or any other magic garbage
a @{whatever} b {
    color: red;
}

All 14 comments

Well, they change the draft every week (see #1801, #2023). So it's not surprise.
Either way you can always use escaping:

@whatever: ~">>>"; // or any other magic garbage
a @{whatever} b {
    color: red;
}

any update on this issue other than the answer above?

I don't think so. Or will _you_ submit a PR (adding the new combinator syntax and removing an old one) _every_ time they change the draft?

Well, this has been stable for over a year, so honestly saying "every time they change the draft' is a bit misleading

@tigerhawkvok A year is just a twink in the CSS realm. I usually like to recall of CSS vars that were hanging there for _decades_ and yet changed the syntax at Draft->CR transition almost at the last moment...
Either way, I don't see how this "over a year" changes anything - if none is willing to implement and then _maintain_ any draft staff, it's not going to appear itself. And after #1801, #2023 boogie-woogie (leaving some garbage in the code-base) it's no wonder these things are treated sceptically.

Can we have >>> selector soon?

Maybe less should consider about support >>> now?

https://github.com/vuejs/vue-loader/issues/913

I'm with @seven-phases-max. There's still some debate on if shadow-piercing combinators are going to ever make it, since there are some that debate the philosophy of it (preferring locally-scoped styles). It's not tracked on caniuse.com, it doesn't have browser support, so that's why it's not supported (natively) in Less. But, as pointed out, it can be hacked in. I recommend closing this issue and re-opening only if this reaches CR status.

I'm working on an angular app and believe we should start switching over to using >>> instead of /deep/.

Why not support >>>. It is valid .css, so why not? Perhaps I'm being naive but in looking at the /deep/ notation I found this SO issue that led me to believe that we should be using >>> instead, however less doesn't support it. What am I missing?

@IEvangelist Regarding Angular stuff according to this post apparently you don't need >>> if you use ::ng-deep instead. And bottom line is >>> or /deep/ will be deprecated from css as far as I understood.

::ng-deep is not working for me, because I'm dealing with a vue app, not an
angular app.

On Wed, 30 Aug 2017, 05:37 Amin Pakseresht notifications@github.com wrote:

According to this post
https://angular.io/guide/component-styles#deprecated-deep--and-ng-deep
apparently you don't need >>> if you use ::ng-deep instead. And bottom
line is >>> or /deep/ will be deprecated from css as well as far as I
understood.

—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
https://github.com/less/less.js/issues/2623#issuecomment-325811803, or mute
the thread
https://github.com/notifications/unsubscribe-auth/AFJBf4ZyVbcJ0spORtCXTC9aSEXCOqvkks5sdISggaJpZM4FOiQI
.

@Jack-Works it's already explained for now you can use escape string as:

@deep: ~'>>>';
// use @deep value in your selectors
.base-class @{deep} .deep-selector-class { }

Closing until they make a final decision (according to latest rumors >>> is going to be kicked out too).
The universal workaround (see the escaping trick above) is given and it fits any experimental/draft combinator/selector syntax just fine.

TODO: Open a generic issue to make combinator parsing more "relaxed" to accomodate some anticipated syntax (e.g. https://drafts.csswg.org/selectors-4/#descendant-combinators etc., possibly including even not existing things like >>>>> and /*&^$*^&$/ with a low level warnings or so).

@seven-phases-max I agree it would be forward-thinking to think of a a regex that would just capture any experimental combinators. I'm not sure there's a lot of reason for Less to be terribly discriminating with selectors. But it's true that browsers are intent now on removing shadow-piercing of any kind as an unwanted complexity.

Was this page helpful?
0 / 5 - 0 ratings

Related issues

awebdev picture awebdev  Â·  4Comments

Oskariok picture Oskariok  Â·  6Comments

joe223 picture joe223  Â·  4Comments

xblakestone picture xblakestone  Â·  3Comments

seven-phases-max picture seven-phases-max  Â·  6Comments