Skip to main content

JavaScript and CSS changes don't show up in my web page

 This could be a common issue you may face if you just started some web development. Sometimes you may feel that a change you made in your CSS or Javascript, never work in your browser. Practically you may waste more time troubleshooting your CSS or Javascript issues without actually understanding why it doesn't show up when you run it in the web browser.

Mostly this happens when you have externalized Javascript or CSS with something like below.


<link rel="stylesheet" href="mystyles.css" />

<script src="myjavascript.js"></script>


The issue with this would be caching. Web browsers tend to cache any styles or javascript files in the clientside so the browser can save up bandwidth without downloading the same set of Javascript and CSS files every time you open the website.

You can see this behavior if you open the developer tools' network section in the Chrome browser.

Browser cache
Browser caching


Yet, when you try to make some changes, it wouldn't show up if you try to view that changes in the browser, because the browser already has a cached version of that Javascript or CSS with it so it doesn't want to download a new copy from the website again.


Solution (During Development)

The solution to this also in the same dev tools. Notice the small checkbox Disable Cache. If you check this, it will force the browser to always download the latest copy from the server instead of reusing the cache.

Disable Browser cache
Disable browser cache


This is a simple trick, but most of the time you may end up wasting lots of time by troubleshooting non-existing errors in your Javascript or CSS. It is a good practice to always keep your Disable Cache checkbox checked while you are developing. 


Note: Even if you have checked this Disable cache checkbox, it works only when the developer tools window is opened.


Solution (During the release)

Imagine that you are updating your website with some new features, bug fixes, or changes related to Javascript or CSS. Actual endures also end up having the same issue if they have a cached copy of your Javascript file or the CSS in their browsers. They usually do. So they won't be able to see the updates in your Javascript or stiles.

The solution for this would be versioning your style sheet and the Javascript like below.

<link rel="stylesheet" href="mystyles.css?v=1" />

<script src="myjavascript.js?v=2"></script>

This is very important to update your script and style version whenever you do any change. If you forget to do this, it could lead to various issues due to having the browser cache in the client's browsers.


This could be just common practice for most of the web developers, but if you are just starting, hope this would be helpful.

Comments

Popular posts from this blog

Java, how to create a list with a single element

 I wanted to create a Java List with a single element. Yet, I wanted to add more elements later. So, I was looking for a couple of ways to do this. So far there are multiple elegant ways to create a list with a single element with a one-liner. Not so much for a modifiable list though. Here's what I gathered so far. Followings are a few ways of creating a list with strictly a single entry. Can't add more elements. 1. Collections.singletonList() This returns an immutable list that cannot be modified or add more elements. // An immutable list containing only the specified object. List<String> oneEntryList = Collections. singletonList ( "one" ) ; oneEntryList.add( "two" ) ; // throws UnsupportedOperationException 2.  Arrays.asList() This returns a fixed-size list consisting of the number of elements provided as arguments. The number of elements provided would be an array hence the size is fixed to the length of the array. // Returns a fixed-size list List...

Ubuntu DNS issue fix DNS_PROBE_FINISHED_BAD_CONFIG

Issue  I've been playing with a VPN and somehow it messed up my DNS resolution configurations. Chrome gives  DNS_PROBE_FINISHED_BAD_CONFIG  error and can't ping google. So it seemed to be an issue with the DNS. Of course, restarting didn't fix it. I tried DNS lookup which gave me below. To make sure this is somehting to do with my DNS confgis, I ran the same by providing the google DNS servers.  It works, which means my default DNS is not working for some reason. To make sure this, ran the below command. systemd-resolve --status Output has an entry for DNS Servers, which was  ::1 Fix 1. Edit the file /etc/systemd/resolved.conf. sudo vi /etc/systemd/resolved.conf 2. Add new DNS entries. I added 2 google DNS and the cloudflare DNS sever. [Resolve] DNS=8.8.8.8 8.8.4.4 1.1.1.1 3. Restart the systemd-resolved and check the configuration is persisted in /run/systemd/resolve/resolv.conf file. sudo service systemd-resolved restart cat /run/systemd/resolve/resolv.co...

How to fix SSLHandshakeException PKIX path building failed in Java

TL ; DR 1. Extract the public certificate of the website/API that you are trying to connect from your Java application. Steps are mentioned in this post 2. Use the Java keytool to install the extracted certificate into the "cacerts" file (Trust store) keytool -import -trustcacerts -alias <domain name> -file <public certificate>.cert -keystore /path_to_java_home/jre/lib/security/cacerts -storepass changeit 3. Restart your Java application Exception A typical exception stack trace would look like below. javax.net.ssl. SSLHandshakeException : sun.security.validator.ValidatorException: PKIX path building failed : sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target at sun.security.ssl.Alerts.getSSLException(Alerts.java:192) at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1959) at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:302) at sun.security.ssl.Handshake...