A client has changed their CSP to ban inline styles on their server. As far as I can tell, this means that we can no longer use JS to dynamically position/animate/style HTML elements e.g. we can't detect the position of a DOM element and position another element next to it via JS.
Is this correct? Is there a workaround for us to dynamically animate DOM elements with this CSP restriction in place?
The proper workaround for this issue is to use the CSS Object Model (CSSOM).
Given the following ways of setting the style:
<p style="left: 343px">...</p> // fails due to CSP
document.getElementById(id).setAttribute('style', 'left: 343px'); // fails due to CSP
document.getElementById(id).style.left = '343px';
Only the last one will successfully comply with a CSP directive of style-src: self
(because it's using the CSSOM).
That's why using jQuery's .css() function works:
When using .
css()
as a setter, jQuery modifies the element'sstyle
property. For example,$( "#mydiv" ).css( "color", "green" )
is equivalent todocument.getElementById( "mydiv" ).style.color = "green"
.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With