javascript - SyntaxHighlighter 和 jQuery 的 IE 错误 - "Unable to get value of the property ' slice' : object is null or undefined"

标签 javascript jquery html syntaxhighlighter xregexp

我真的很喜欢SyntaxHighter - 事实证明,这是看起来最漂亮的代码。不幸的是,我已经对 IE7 和 IE8 中的一个可怕的 JS 错误大喊大叫,这将阻止我完全使用这个本来很优秀的插件。

这是一个测试用例。我包括

<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>

在我的标题中,以便 IE7 和 IE8 可以识别 HTML5 元素。

在我的测试页面的正文中,我只有一些导航项:

<nav id="top-nav" class="f16 clearfix">
    <ul id="nav-menu">
        <li><a href="index.htm">Home</a></li>
        <li><a href="branding.htm">Branding</a>
            <ul class="nav-submenu">
                <li><a href="logos1">Logos 1</a></li>
                <li><a href="logos2">Logos 2</a></li>
                <li><a href="logos3">Logos 3</a></li>
            </ul>
        </li>
    </ul>
</nav>

除了 JQuery 和 SyntaxHighlighter 的这些内容以及这个初始化 SyntaxHighlighter 并尝试向导航菜单添加事件监听器的小脚本之外,没有其他任何内容。

<script src="extra/syntax-highlighter/shCore.js"></script>
<script src="extra/syntax-highlighter/shBrushJScript.js"></script>
<script src="extra/syntax-highlighter/shBrushXml.js"></script>
<script>
    SyntaxHighlighter.all();

    $(document).ready(function(){
        $('#nav-menu').on('mouseenter', function () {
            $(this).children('.nav-submenu').fadeIn('fast');
        })
    })
</script>

当我在 IE7 和 IE8 中查看此页面时,出现错误“SCRIPT5007:无法获取属性“切片”的值:对象为 null 或未定义”,并且我的 jQuery 无法工作。

通过阅读,我了解到这可能与 SyntaxHighlighter 使用的 XRegExp 有关。根据this jQuery bug ticket XRegExp 中存在一些错误,该错误已在 XRegExp 1.5.1 中修复。不幸的是,这个修复似乎没有找到 SyntaxHighlighter 的方法。 SyntaxHighlighter 的 Bitbucket page 上有一个类似错误的讨论。 。我尝试了一个人制作的修改后的 XregExp.js 和 shCore.js 文件,但它没有解决我的问题。

还有人遇到过这种事情吗?否则我将不得不使用其他一些蹩脚的语法荧光笔!

最佳答案

我在 IE7/8 中遇到了同样的问题

我最终通过从 GitHub ( https://github.com/alexgorbatchev/SyntaxHighlighter ) 获取最新版本的插件来修复它们,该版本比 BitBucket 上的存储库更新。

关于javascript - SyntaxHighlighter 和 jQuery 的 IE 错误 - "Unable to get value of the property ' slice' : object is null or undefined",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9753277/

相关文章:

javascript - 如何在文本字段中显示所有选定的选项

javascript - 如何让这个功能在表单提交时进行

javascript - 在 jquery 搜索中添加 location.hash

javascript - 在外部单击时隐藏侧边栏组件

html - 如何让第二个 div 在没有滚动条的情况下填充屏幕的剩余高度?

javascript - 如何将 .toggleClass() 与 .appendTo() 结合使用?

javascript - 当以 Angular 单击时,如何从数据表中检索单个对象?

javascript - 2个表,需要为每个匹配行设置最大高度的行

javascript - AngularJS 中 ng-model 的复选框限制

jquery - 固定导航菜单 - 如何使用 JavaScript 进行动画进出?