There are lots of tools for finding unused CSS rules in stylesheets, such as Chrome Audits and the Dust-Me Selectors add-on for Firefox (unfortunately not compatible with Firefox Quantum).
But what about the other way around?
How do I find classes that are in my HTML, that do not exist in my stylesheets?
4 Answers
Answers 1
This may be helpful: https://code.google.com/p/find-unused-classes/ . According to the description:
It shows classes that exist in css selectors and do not exist on html page and like-verse.
As Jim said, be warned that some classes may be unused by your stylesheets but still used in JavaScript.
Answers 2
HTML Inspector from https://github.com/philipwalton/html-inspector has this as one of its features:
Unused Classes: Sometimes you'll remove a CSS rule from your stylesheet but forget to remove the class from the HTML. The "unused-classes" rule compares all the class selectors in the CSS to the classes in the HTML and reports any that aren't being used.
Classes that are in the HTML as JavaScript hooks can be ignored via a whitelist. By default, any class prefixed with
js-
,language-
, orsupports-
is whitelisted. More information on the rationale behind this rule can be found here.
In its FAQ you will find a bookmarklet.
There is also grunt-unclassify but that project seems dead.
Answers 3
This is a partial answer on how to get the class names in html
var classesEvery = []; var elementsEvery = document.querySelectorAll('*'); for (var i = 0; i < elementsEvery.length; i++) { var classes = elementsEvery[i].className.toString().split(/\s+/); for (var j = 0; j < classes.length; j++) { var thisClass = classes[j]; if (thisClass && classeEvery.indexOf(thisClass) === -1) classeEvery.push(thisClass); } }
One can get the Class names in the html file using this Javascript code. For getting all classes used in CSS, try list-selectors. Still thinking on how to get class names used in Javascript angularJS. Added a working snippet with random HTML classes to test the js.
var classesEvery = []; var elementsEvery = document.querySelectorAll('*'); for (var i = 0; i < elementsEvery.length; i++) { var classes = elementsEvery[i].className.toString().split(/\s+/); for (var j = 0; j < classes.length; j++) { var thisClass = classes[j]; if (thisClass && classesEvery.indexOf(thisClass) === -1) classesEvery.push(thisClass); } } console.log(classesEvery);
.hidden { display: none; }
<!-- Some random HTML code. --> <div ng-controller="HomeController" class="container hidden"> <span>Simple Notifications:</span> <div class="rows"> <div class="col-md-2"><button class="btn btn-primary" href ng-click="simple()">Simple notification</button></div> <div class="col-md-2"><button class="btn btn-warning" href ng-click="warning()">Warning notification</button></div> <div class="col-md-2"><button class="btn btn-success" href ng-click="success()">Success notification</button></div> <div class="col-md-2"><button class="btn btn-danger" href ng-click="error()">Error notification</button></div> <div class="col-md-2"><button class="btn btn-grimace" href ng-click="wait()">Wait notification</button></div> <div class="col-md-2"><button class="btn btn-primary" href ng-click="pop()">Link to other page</button></div> </div> <hr/> <span>Addding Option from Script:</span> <div class="rows"> <div class="col-md-6"> <Span>With CLose button</span> <button class="btn btn-primary" href ng-click="close()">Close Button </button> </div> <div class="col-md-6"> <Span>Fade after 1 Sec</span> <button class="btn btn-primary" href ng-click="timeout()">Html notification</button> </div> </div> <br/> <hr/> <span>Custom Notification and Body output type:</span> <div class="rows"> <div class="col-md-3"><button class="btn btn-primary" href ng-click="Custom_temp()">Custom template</button></div> <div class="col-md-3"><button class="btn btn-primary" href ng-click="trusted_html()">Trusted HTML</button></div> <div class="col-md-3"><button class="btn btn-primary" href ng-click="default_temp()">Default Template</button></div> <div class="col-md-3"><button class="btn btn-primary" href ng-click="file_custom_temp()">Including file from Folder</button></div> </div> <script type="text/ng-template" id="myTemplate.html"> <div class="Custom_temp_html"> <p>Notice, custom temlate is not in the list</p> </div> </script> </div>
Answers 4
The tool grunt-unclassify
looks promising too, altough its use doesn't seem straightforward:
https://medium.com/@mariusc23/remove-unused-css-classes-in-html-bbb856da8bdf#.55u0uokfb
0 comments:
Post a Comment