Skip to content

Instantly share code, notes, and snippets.

@rslahmed
Last active July 15, 2023 06:46
Show Gist options
  • Save rslahmed/94229152d283a28b3b463672b35240c2 to your computer and use it in GitHub Desktop.
Save rslahmed/94229152d283a28b3b463672b35240c2 to your computer and use it in GitHub Desktop.
change SVG Color with img class
// way 1:
/**
* Replace all SVG images with inline SVG
*/
jQuery('img.svg').each(function(){
var $img = jQuery(this);
var imgID = $img.attr('id');
var imgClass = $img.attr('class');
var imgURL = $img.attr('src');
jQuery.get(imgURL, function(data) {
// Get the SVG tag, ignore the rest
var $svg = jQuery(data).find('svg');
// Add replaced image's ID to the new SVG
if(typeof imgID !== 'undefined') {
$svg = $svg.attr('id', imgID);
}
// Add replaced image's classes to the new SVG
if(typeof imgClass !== 'undefined') {
$svg = $svg.attr('class', imgClass+' replaced-svg');
}
// Remove any invalid XML tags as per http://validator.w3.org
$svg = $svg.removeAttr('xmlns:a');
// Replace image with new SVG
$img.replaceWith($svg);
}, 'xml');
});
// way 2:
// SVG img to SVG inline convertion
function genarate_svg(){
jQuery('img.svgInline').each(function(){
var $img = jQuery(this);
var imgID = $img.attr('id');
var imgClass = $img.attr('class');
var imgURL = $img.attr('src');
jQuery.get(imgURL, function(data) {
// Get the SVG tag, ignore the rest
var $svg = jQuery(data).find('svg');
// Add replaced image's ID to the new SVG
if(typeof imgID !== 'undefined') {
$svg = $svg.attr('id', imgID);
}
// Add replaced image's classes to the new SVG
if(typeof imgClass !== 'undefined') {
$svg = $svg.attr('class', imgClass+' replaced-svg');
}
// Remove any invalid XML tags as per http://validator.w3.org
$svg = $svg.removeAttr('xmlns:a');
$svg = $svg.removeAttr('width');
$svg = $svg.removeAttr('height');
// Replace image with new SVG
$img.replaceWith($svg);
$("defs").remove();
}, 'xml');
// console.log("in");
});
}
//css
.red_svg path, .red_svg polygon, .red_svg rect, .red_svg circle {
fill: #ff0000 !important;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment