在我的Salesforce应用程序中,我希望用户输入日期/时间值,但时间部分是可选的。有没有办法实现这一目标。谢谢。
答案 0 :(得分:2)
如果时间是可选的,只需使用00:
Datetime myDate = datetime.newInstance(2012, 10, 5, 00, 00, 0);
答案 1 :(得分:2)
您是否可以使用两个字段(一个日期和另一个文本字段用于时间)。然后将这些字段连接到日期时间公式字段中。这不会有帮助吗?
答案 2 :(得分:2)
作为一种解决方案,我不是使用自定义对象字段类型的DateTime值,而是在VF控制器级别中保留单独的Date值和Time值,并将这些值组成一个DateTime。
Apex代码如下:
// Compos DateTime with Date & Time values
this.jobOccurrence.Date_Time_Sampled__c = DateTime.parse(this.dateSampled.trim() + ' ' + this.timeSampled.trim());
VisualForce代码如下所示,
<apex:page>
<!-- Style sheet for timepicker -->
<link rel="stylesheet" media="all" type="text/css" href="{!URLFOR($Resource.jquery_ui_custom)}" />
<style>
#ui-datepicker-div, .ui-datepicker{ font-size: 70%; }
.ui-timepicker-div .ui-widget-header { margin-bottom: 8px; }
.ui-timepicker-div dl { text-align: left; }
.ui-timepicker-div dl dt { height: 25px; margin-bottom: -25px; }
.ui-timepicker-div dl dd { margin: 0 10px 10px 65px; }
.ui-timepicker-div td { font-size: 90%; }
.ui-tpicker-grid-label { background: none; border: none; margin: 0; padding: 0;
</style>
<!-- javascript for timepicker -->
<script type="text/javascript" src="{!URLFOR($Resource.jquery)}"></script>
<script type="text/javascript" src="{!URLFOR($Resource.jquery_ui_custom_min)}"></script>
<script type="text/javascript" src="{!URLFOR($Resource.jquery_ui_timepicker_addon)}"></script>
<script type="text/javascript">
/* Set Timepicker to component */
function setTimepicker(componentObj) {
$(componentObj).timepicker({ show24Hours: false, timeFormat: 'hh:mm TT', ampm: true});
}
</script>
<apex:form id="frmMain">
<!-- Date -->
<apex:inputText value="{!dateSampled}" onfocus="DatePicker.pickDate(false, this.id, false);"/>
<!-- Time -->
<apex:inputText value="{!timeSampled}" onfocus="setTimepicker(this);"/>
</apex:form>
</apex:page>