大佬教程收集整理的这篇文章主要介绍了twitter-bootstrap – xPages中的bootstrap 3的Eonasdan datetimepicker,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
以下代码在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绑定到该字段没有任何问题.当您尝试选择模型框显示的时间并允许您选择时间时,当您尝试单击该字段以关闭模型时间控件时会发生错误.
如文档中所述,我已将插件和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  <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,请注明来意。