.js file works in chrome and firefox but not IE

前端 未结 3 905
悲哀的现实
悲哀的现实 2021-01-06 08:00

When testing my website out in IE11 certain parts of it don\'t work and I believe the issue lies with my \'custom.js\' file as all the problems link to that js. However, t

相关标签:
3条回答
  • 2021-01-06 08:22

    Problem: Internet Explorer 11, released in 2013, does not run ECMAScript 2015 (for obvious reason).

    Dirty Way: Babel (Standalone)

    The quickest but also the least efficient way. Don't use in production.

    <!-- Load the in-browser babel compiler.  Make sure page encoding is UTF-8. -->
    <script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>
    <!-- Set script type to text/babel for on-the-fly conversion and execution -->
    <script type="text/babel" src="custom.js"></script>
    <!-- Babel need to read the script through ajax, same origin policy applies. -->
    

    Painful Way: Rewrite in ES5

    Simply rewrite the last few lines of custom.js in ES5, and be extra care not to use any ES6/7/8+ features in the future:

    var divs = $(".owl-news > .news-v2"),
       array = [
          { length: 1, num: 4 },
          { length: 2, num: 3 },
          { length: 2, num: 3 },
          { length: 3, num: 2 }  
       ],
       i = 0;
    
    array.forEach( function( item ) {
      divs.slice(i, i+item.length).wrapAll( "<div id='news-"+item.num+"' class='col-md-"+item.num+"'></div>" );
      i += item.length;
    } );
    

    Systematic Way: Build Script

    A proper build system can help you manage the project, such as automatic testing and deployment to test and production system. One of the things they can do is to convert your ES6 code to ES5 on deployment and maybe minify / obfuscate them, for example with Babel, Traceur, or Closure.

    The "build system" can be as simple as a batch file. If you tell your boss it'll protect valuable company intellectual properties (s)he may give you the time you need to properly learn one.


    Save the Web: Don't support IE 11

    I know, I know. You won't be asking if it's an option.

    But your boss may not be aware that IE support costs more development time, which means higher cost, slower delivery, and less profit.

    Few people (3.2%) use IE 11 in the real world - less than "UC Browser" (8%), "Firefox" (6%), "Samsung Internet" (3.6%), or "Opera" (3.4%). (Statcounter May 2017 global stat.) If a user or client ask why don't you support the Samsung browser, saying no one use it is not a good excuse, as IE 11 has even less users.

    Most IE users have learned that if it doesn't work in IE, try Chrome. Encourage them to use Chrome first and IE last will be good. They are safer, the web is brighter, everyone is happy.

    0 讨论(0)
  • 2021-01-06 08:38

    Easy way to check if your file has non-es5 syntax:

    npm install -g es-check
    es-check es5 offendingFile.js
    
    0 讨论(0)
  • 2021-01-06 08:41

    You're using the javascript let keyword, which is only available on IE11. More information here...

    If the problem persists and you are sure the code is compiling, then you should activate the browser's debugger to figure out what's going on... Just place the keyword debugger; somewhere in your code, and the browser will suspend execution at that stop allowing you to inspect the variables...

    Something like this:

    debugger;
    $(".helpform-container:not(.displayblock)").hide();
    ...
    $("#news-4").before("<div class='col-md-4'><h3 id='title_featured'>Featured News</h3></div><div class='col-md-8'><h3 id='title_latest'>Latest News</h3></div>");
    
    0 讨论(0)
提交回复
热议问题