Bootstrap   发布时间:2022-04-18  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了twitter-bootstrap – xPages中的bootstrap 3的Eonasdan datetimepicker大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我在我的xpage应用程序中遇到了bootstrap datetiR_37_11845@ePicker控件的问题,我怀疑这与xPages生成控件ID的方式有关.

以下代码在inputText元素上没有id时工作正常.

<script type="text/javascript" src="/fPath/jquery-min.js"></script>
<script type="text/javascript" src="/fPath/bootstrap/js/bootstrap.min.js"></script>
<script type="text/javascript" src="/RfPath/bootstrap-datetiR_37_11845@epicker-3.0.0/js/moment.min.js"></script>
<script type="text/javascript" src="/fPath/bootstrap-datetiR_37_11845@epicker-3.0.0/js/bootstrap-datetiR_37_11845@epicker.min.js"></script>

<div class='input-group date' data-datetiR_37_11845@epicker="true">
    <xp:inputText styleClass="form-control timePicker">
        <xp:this.converter>
            <xp:convertdatetiR_37_11845@e type="time" timestyle="short" />
        </xp:this.converter>
    </xp:inputText>
    <span class="input-group-addon">
        <span class="glyphicon glyphicon-time"></span>
    </span>
</div>

一旦我添加一个id,我在单击远离/退出控件时收到以下错误

错误:语法错误,无法识别的表达式:unsupported pseudo:_id1

id是需要将数据映射回文档但我实际上并没有使用它来附加datetiR_37_11845@epicker – 我正在使用一个类:

$('.timePicker').each(function(i,el){SHARED.timePickerOpen(el)}) 

SHARED = {
    timePickerOpen: function(el){
        $(el).datetiR_37_11845@epicker({
            pickDate: false,pickTime: true,useCurrent: true,minuteStepping:5  
        });
    }
}

更新#1:

听起来有点误会,所以我会试着进一步解释……

>在测试中,我用纯HTML编写代码,为字段提供ID和
它工作正常.
>如果我使用Xpage字段(domino生成ID
使用冒号)日期选择器失败并出现上述错误.
>我不使用ID将事件绑定到字段,我使用类get
然后该字段将datetiR_37_11845@epicker控件绑定到它.

问题似乎是使用字段ID的datetiR_37_11845@epicker.即使我通过类名(不是id)获取字段,datetiR_37_11845@epicker代码似乎想要在字段中找到一个id. datetiR_37_11845@epicker绑定到该字段没有任何问题.当您尝试选择模型框显示的时间并允许您选择时间时,当您尝试单击该字段以关闭模型时间控件时会发生错误.

解决方法

有趣的插件.我创建了一个示例页面,看看我是否可以将它与XPage集成,如果我得到相同的错误.在完成我在下面描述的内容之后,我让它在没有您报告的问题的情况下运行.

如文档中所述,我已将插件moment.js添加数据库中,并使用示例代码here构建一个简单的演示页面.在数据库中我使用的是Bootstrap4XPages插件(March发行版),因此已经加载了Bootstrap 3.1.1.

<?xml version="1.0" encoding="UTF-8"?>
<xp:view
  xmlns:xp="http://www.ibm.com/xsp/core"
  xmlns:xc="http://www.ibm.com/xsp/custom">

<xp:this.resources>
    <xp:script
        src="momentjs-2.7.0/moment.min.js"
        clientSide="true">
    </xp:script>
    <xp:script
        src="eonasdan-datetiR_37_11845@epicker/js/bootstrap-datetiR_37_11845@epicker.min.js"
        clientSide="true">
    </xp:script>
    <xp:styleSheet
        href="eonasdan-datetiR_37_11845@epicker/css/bootstrap-datetiR_37_11845@epicker.min.css"></xp:styleSheet>
</xp:this.resources>

<xp:div
    xp:key="faCETR_37_11845@iddle">

    <p>
        This page uses&#160;
        <a
            href="https://github.com/Eonasdan/bootstrap-datetiR_37_11845@epicker">Eonasdan's Bootstrap datetiR_37_11845@ePicker</a>
        .
    </p>

    <div
        class="col-sm-6">
        <div
            class="form-group">
            <div
                class='input-group date'
                id='datetiR_37_11845@epicker1'>

                <xp:inputText
                    id="inputText1"
                    styleClass="form-control">
                    <xp:this.converter>
                        <xp:convertdatetiR_37_11845@e
                            type="both"
                            timestyle="short" />
                    </xp:this.converter>
                </xp:inputText>
                <span
                    class="input-group-addon">
                    <span
                        class="glyphicon glyphicon-calendar"></span>
                </span>
            </div>
        </div>
    </div>

</xp:div>

<xp:scriptBlock
    id="scriptBlock1">

    <xp:this.value><![CDATA[$(function () {
    $('#datetiR_37_11845@epicker1').datetiR_37_11845@epicker();
    });]]></xp:this.value>
</xp:scriptBlock>

</xp:view>

首次打开XPage在Chrome控制台中给出了一个熟悉的错误

Uncaught TypeError: undefined is not a function

我之前见过一个:较新的jQuery插件尝试使用它的AMD加载器,但这与XPage中的Dojo实现不相符.我知道有两种解决方法

>使用@L_502_3@在Dojo之前加载(JavaScript)资源.
>更改您正在使用的库的源代码.这种方法也不完美,但我喜欢的方法.在JavaScript@L_450_44@中(在本例中名为bootstrap-datetiR_37_11845@epicker.js),您需要找到确定它是否可以使用AMD加载程序的行.它们通常可以在JavaScript@L_450_44@的开头或结尾找到.

这是你在bootstrap-datetiR_37_11845@epicker.js中寻找的代码

; (function (factory) {
if (typeof define === 'function' && define.amd) {
    // AMD is used - Register as an anonymous module.
    define(['jquery','moment'],factory);
} else {
    // AMD is not used - Attempt to fetch dependencies from scope.
    if (!jQuery) {
        throw 'bootstrap-datetiR_37_11845@epicker requires jQuery to be loaded first';
    } else if (!moment) {
        throw 'bootstrap-datetiR_37_11845@epicker requires moment.js to be loaded first';
    } else {
        factory(jQuery,moment);
    }
}
}

然后我们禁用(或删除;您的选择)AMD部分:

; (function (factory) {
//if (typeof define === 'function' && define.amd) {
    // AMD is used - Register as an anonymous module.
//    define(['jquery',factory);
//} else {
    // AMD is not used - Attempt to fetch dependencies from scope.
    if (!jQuery) {
        throw 'bootstrap-datetiR_37_11845@epicker requires jQuery to be loaded first';
    } else if (!moment) {
        throw 'bootstrap-datetiR_37_11845@epicker requires moment.js to be loaded first';
    } else {
        factory(jQuery,moment);
    }
//}
}

现场演示可以在here找到.

大佬总结

以上是大佬教程为你收集整理的twitter-bootstrap – xPages中的bootstrap 3的Eonasdan datetimepicker全部内容,希望文章能够帮你解决twitter-bootstrap – xPages中的bootstrap 3的Eonasdan datetimepicker所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。