I have a website by mean-stack
.
Normally, all my external references are listed in index.html
I realize that one external JS library (e.g., https://cdnjs.cloudflare.com/troublelibrary.js) I am using has some conflit with a part of my website. So a workaround I am looking for is to NOT load it for a specific path https://www.myexample.com/specific
.
Does anyone know how to achieve this in the routing?
Edit 1: (see the full question here)
Actually, the library that has conflit is history.js
. My initial code which loads it all the time is as follows. As a result https://localhost:3000/home
in a browser is always https://localhost:3000/home
(i.e., will not add #
because of history.js
)
<script src="https://appsforoffice.microsoft.com/lib/1/hosted/office.js"></script>
<script src="https://cdn.rawgit.com/devote/HTML5-History-API/master/history.js"></script>
Then, if I try the following code, as Ben suggests:
<script src="https://appsforoffice.microsoft.com/lib/1/hosted/office.js"></script>
<script>
var newScript = document.createElement('script');
newScript.src = 'https://cdn.rawgit.com/devote/HTML5-History-API/master/history.js';
document.head.appendChild(newScript);
console.log(window.location.href)
</script>
I realize that for the first time of loading https://localhost:3000/home
will not change. But, if I refresh the browser, it can change to https://localhost:3000/#/home
.
So appending the script is not exactly the same as a direct reference, does anyone know why?
This is one way to do it:
Add this to the
<head>
of the document. It will not load the trouble script on the page you specify in theif
statement. Make sure not to load the trouble script anywhere else on the page as well.