- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有以下 HTML,当您单击 Add Column
按钮时,它会添加我的表格标题。然后,当您单击 Add Row
时,它会创建行。
我需要添加一个日期选择器并创建按钮,以便用户可以选择一个日期范围,然后该日期范围需要进入相应的旅行日期行。
用户需要点击Add Column
,然后需要点击Add Date Range
,然后它应该在单元格中放置一个日期。添加日期范围需要在每一行中显示自己的列。然后,当用户选择一个范围时,它应该显示如下内容:Fri, 20 Sep - Mon, 7 Oct 2013
HTML:
<button id="addcolumn">Add Column</button>
<button id="addrow">Add Row</button>
<button id="adddaterange">Add Date Range</button>
<table width="100%" border="1" cellpadding="0" cellspacing="0">
<thead id="theads">
<tr>
<th class="th">Travel Dates</th>
<th class="th">Duration</th>
<th class="th">Trip Cost</th>
</tr>
</thead>
<tbody id="tbody">
</tbody>
</table>
jQuery:
$(document).ready(function () {
var $cell = $('<td>', {
'class': 'td',
'align': 'center',
'contenteditable': '',
'text': 'Content'
});
var $header = $('<th>', {
'class': 'th',
'contenteditable': '',
'text': 'Heading'
});
$('#addcolumn').click(function() {
$header.clone().appendTo('thead tr');
$cell.clone().appendTo('tbody tr');
});
$('#addrow').click(function(){
var $row = $('<tr>');
$('th').each(function() {
$cell.clone().appendTo($row);
});
$row.appendTo('tbody');
});
});
JSFIDDLE: http://jsfiddle.net/prBZS/35/
最佳答案
我制作了一个 fiddle ,我演示了它是如何工作的;我希望我能正确理解你在问什么。
该项目使用(我不能将其隐藏...)输入字段并附加一个 jQuery datepick
;它没有使用标准的 jQuery UI 日期选择器,因为它不支持范围选择。
当你添加一个列时,它会被添加一个类 canDatePicker
到列的每个单元格,这个类告诉你可以“附加”一个日期选择器到单元格。为每个单元格使用一个 contenteditable 我通过添加类 focused
来管理当前的焦点单元格,所以我知道当前的单元格。当您将日期选择器附加到单元格时,它会向单元格添加一个类 hasDatePicker
以供将来对该单元格进行新的点击。
当您从日期选择器中选择范围时,范围将设置在单元格的文本上。如果您再次单击该单元格,则会打开日期选择器,其中包含之前选择的单元格范围。
如果您需要更多代码解释,请告诉我。
代码:
$(document).ready(function () {
$('#datepicker').datepick({
rangeSelect: true,
onClose: function () {
var dates = $('#datepicker').datepick('getDate');
var value = '';
for (var i = 0; i < dates.length; i++) {
value += (i == 0 ? '' : ' - ') + $.datepick.formatDate(dates[i]);
}
$('.focused').html(value);
}
});
$(document).on('focus', '.hasDatePicker', function (e) {
var dates = $(this).text().split(' - ');
$("#datepicker").datepick('setDate', dates);
$("#datepicker").datepick('show')
});
$(document).on('focus', 'td', function (e) {
$("td").removeClass('focused');
$(e.target).addClass('focused');
});
var $cell = $('<td>', {
'class': 'td',
'align': 'center',
'contenteditable': '',
'text': 'Content'
});
var $header = $('<th>', {
'class': 'th',
'contenteditable': '',
'text': 'Heading'
});
$('#addcolumn').click(function () {
$header.clone().appendTo('thead tr');
$cell.clone().appendTo('tbody tr');
$('table>tbody>tr>td:nth-child(n+4)').addClass('canDatePicker');
});
$('#addrow').click(function () {
var $row = $('<tr>');
$('th').each(function () {
$cell.clone().appendTo($row);
});
$row.appendTo('tbody');
$('table>tbody>tr>td:nth-child(n+4)').addClass('canDatePicker');
});
$('#adddaterange').click(function () {
if ($(".focused").length == 0 || !($(".focused").hasClass("canDatePicker"))) return
$(".focused").addClass("hasDatePicker");
$("#datepicker").datepick('show')
});
});
演示:http://jsfiddle.net/IrvinDominin/WzkBS/
启动演示,按“添加行”、“添加列”,聚焦新单元格并按“添加日期范围”,然后尝试使用演示。
关于javascript - 使用 jQuery 添加日期范围选择器并更新内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18428981/
我之前让 dll 注入(inject)器变得简单,但我有 Windows 7,我用 C# 和 C++ 做了它,它工作得很好!但是现在当我在 Windows 8 中尝试相同的代码时,它似乎没有以正确的方
我正在尝试制作一个名为 core-splitter 的元素,该元素在 1.0 中已弃用,因为它在我们的项目中起着关键作用。 如果您不知道 core-splitter 的作用,我可以提供一个简短的描述。
我有几个不同的蜘蛛,想一次运行所有它们。基于 this和 this ,我可以在同一个进程中运行多个蜘蛛。但是,我不知道如何设计一个信号系统来在所有蜘蛛都完成后停止 react 器。 我试过了: cra
有没有办法在达到特定条件时停止扭曲 react 器。例如,如果一个变量被设置为某个值,那么 react 器应该停止吗? 最佳答案 理想情况下,您不会将变量设置为一个值并停止 react 器,而是调用
https://code.angularjs.org/1.0.0rc9/angular-1.0.0rc9.js 上面的链接定义了外部js文件,我不知道Angular-1.0.0rc9.js的注入(in
我正在尝试运行一个函数并将服务注入(inject)其中。我认为这可以使用 $injector 轻松完成.所以我尝试了以下(简化示例): angular.injector().invoke( [ "$q
在 google Guice 中,我可以使用函数 createInjector 创建基于多个模块的注入(inject)器。 因为我使用 GWT.create 在 GoogleGin 中实例化注入(in
我在 ASP.NET Core 1.1 解决方案中使用配置绑定(bind)。基本上,我在“ConfigureServices Startup”部分中有一些用于绑定(bind)的简单代码,如下所示: s
我在 Spring MVC 中设置 initBinder 时遇到一些问题。我有一个 ModelAttribute,它有一个有时会显示的字段。 public class Model { privat
我正在尝试通过jquery post发布knockoutjs View 模型 var $form = $('#barcodeTemplate form'); var data = ko.toJS(vm
如何为包含多态对象集合的复杂模型编写自定义模型绑定(bind)程序? 我有下一个模型结构: public class CustomAttributeValueViewModel { publi
您好,我正在尝试实现我在 this article 中找到的扩展方法对于简单的注入(inject)器,因为它不支持开箱即用的特定构造函数的注册。 根据这篇文章,我需要用一个假的委托(delegate)
你好,我想自动注册我的依赖项。 我现在拥有的是: public interface IRepository where T : class public interface IFolderReposi
我正在使用 Jasmine 测试一些 Angular.js 代码。为此,我需要一个 Angular 注入(inject)器: var injector = angular.injector(['ng'
我正在使用 Matlab 代码生成器。不可能包含代码风格指南。这就是为什么我正在寻找一个工具来“ reshape ”、重命名和重新格式化生成的代码,根据我的: 功能横幅约定 文件横幅约定 命名约定 等
这个问题在这里已经有了答案: Where and why do I have to put the "template" and "typename" keywords? (8 个答案) 关闭 8
我开发了一种工具,可以更改某些程序的外观。为此,我需要在某些进程中注入(inject)一个 dll。 现在我基本上使用这个 approach .问题通常是人们无法注入(inject) dll,因为他们
我想使用 swing、spring 和 hibernate 编写一个 java 应用程序。 我想使用数据绑定(bind)器用 bean 的值填充 gui,并且我还希望它反射(reflect) gui
我有这段代码,当两个蜘蛛完成后,程序仍在运行。 #!C:\Python27\python.exe from twisted.internet import reactor from scrapy.cr
要点是 Spring Batch (v2) 测试框架具有带有 @Autowired 注释的 JobLauncherTestUtils.setJob。我们的测试套件有多个 Job 类提供者。因为这个类不
我是一名优秀的程序员,十分优秀!