- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
所以,我想做的是实现一个数据范围选择,它不显示两个日期选择器“从”和“到”。我想让用户在今天、昨天、上周、上个月等之间进行选择。
我在服务器端的应用程序中有类似的东西,但是: 1- 代码看起来很糟糕; 2- 我希望 API 接收“从”和“到”日期,我只希望用户看到一个友好的日期范围选择。
附加信息:我的前端基于 AngularJS。
我希望它看起来像这样:
服务器端的实际代码是这样的:
var today = DateTime.Now.Date;
if (dateRange == (int)DateRange.Custom)
{
var start = DateTime.ParseExact(dateFrom, "dd/MM/yyyy", null);
var end = DateTime.ParseExact(dateTo, "dd/MM/yyyy", null).AddDays(1);
query = query.Where(ss => ss.DateRecevied >= start && ss.DateRecevied < end);
return query;
}
if (dateRange == (int)DateRange.Today)
{
query = query.Where(ss => ss.DateRecevied >= today);
return query;
}
if (dateRange == (int)DateRange.Yesterday)
{
var dateShift = today.AddDays(-1);
query = query.Where(ss => ss.DateRecevied >= dateShift && ss.DateRecevied < today);
return query;
}
if (dateRange == (int)DateRange.ThisWeekFromSunToday)
{
var dt = DateTime.Now.StartOfWeek(DayOfWeek.Sunday);
query = query.Where(ss => ss.DateRecevied >= dt);
return query;
}
if (dateRange == (int)DateRange.ThisWeekFromMonToday)
{
var dt = DateTime.Now.StartOfWeek(DayOfWeek.Monday);
query = query.Where(ss => ss.DateRecevied >= dt);
return query;
}
if (dateRange == (int)DateRange.Last7Days)
{
var dateShift = today.AddDays(-7);
query = query.Where(ss => ss.DateRecevied >= dateShift);
return query;
}
if (dateRange == (int)DateRange.Last14days)
{
var dateShift = today.AddDays(-14);
query = query.Where(ss => ss.DateRecevied >= dateShift);
return query;
}
if (dateRange == (int)DateRange.ThisMonth)
{
var dateShift = new DateTime(today.Year, today.Month, 1);
query = query.Where(ss => ss.DateRecevied >= dateShift);
return query;
}
if (dateRange == (int)DateRange.Last30days)
{
var dateShift = today.AddDays(-30);
query = query.Where(ss => ss.DateRecevied >= dateShift);
return query;
}
if (dateRange == (int)DateRange.LastMonth)
{
var dateShift = new DateTime(today.Year, today.Month, 1);
var dateShift2 = dateShift.AddMonths(-1);
query = query.Where(ss => ss.DateRecevied >= dateShift2 && ss.DateRecevied < dateShift);
return query;
}
if (dateRange == (int)DateRange.AllTime)
{
query = query.AsQueryable();
return query;
}
if (dateRange == (int)DateRange.Last90Days)
{
var dateShift = today.AddDays(-90);
query = query.Where(ss => ss.DateRecevied >= dateShift);
return query;
}
if (dateRange == (int)DateRange.LastWeekFromMonSun)
{
var dateLastWeekMonday = DateTimeExtensions.GetDateForLastWeekMonday(today);
var dateLastWeekSun = DateTimeExtensions.GetDateForLastWeekSun(today).AddDays(1);
query = query
.Where(ss =>
ss.DateRecevied >= dateLastWeekMonday
&&
ss.DateRecevied < dateLastWeekSun);
return query;
}
if (dateRange == (int)DateRange.LastWorkingWeekFromMonFri)
{
var dateLastWeekMonday = DateTimeExtensions.GetDateForLastWeekMonday(today);
var dateLastWeekFri = DateTimeExtensions.GetDateForLastWeekFri(today).AddDays(1);
query = query
.Where(ss =>
ss.DateRecevied >= dateLastWeekMonday
&&
ss.DateRecevied < dateLastWeekFri);
return query;
}
return query;
最佳答案
我最终使用了 MomentJS 库 ( http://momentjs.com ) 并在我的 AngularJS 应用程序上创建了一个新模块。
我将它上传到 GitHub 以供 future 的访问者使用:https://github.com/renatocarrico/js-libraries/blob/master/human-date-range.js
代码(如果链接无法打开):
var options = [{ name: "Custom", id: 1 }, { name: "Today", id: 2 }, { name: "Yesterday", id: 3 }, { name: "This Week (Sun - Today)", id: 4 }, { name: "This Week (Mon - Today)", id: 5 }, { name: "Last 7 Days", id: 6 }, { name: "Last Week (Mon - Sunday)", id: 7 }, { name: "Last Business Week (Mon - Fri)", id: 8 }, { name: "Last 14 days", id: 9 }, { name: "This Month", id: 10 }, { name: "Last 30 Days", id: 11 }, { name: "Last Month", id: 12 }, { name: "Last 90 Days", id: 13 }];
var selectedOption = 2;
function setSelectedOption (optionId) {
selectedOption = optionId;
};
function getOptions() {
return options;
};
function getFromDate() {
//Today
if (selectedOption == 2) {
return new Date();
}
//Yesterday
if (selectedOption == 3) {
return moment().subtract(1, 'd').toDate();
}
//This Week (Sun - Today)
if (selectedOption == 4) {
return moment().day("Sunday").toDate();
}
//This Week (Mon - Today)
if (selectedOption == 5) {
return moment().day("Monday").toDate();
}
//Last 7 Days
if (selectedOption == 6) {
return moment().subtract(7, 'd').toDate();
}
//Last Week (Mon - Sunday)
if (selectedOption == 7) {
return moment().day('Monday').subtract(1, 'w').toDate();
}
//Last Business Week (Mon - Fri)
if (selectedOption == 8) {
return moment().day('Monday').subtract(1,'w').toDate();
}
//Last 14 days
if (selectedOption == 9) {
return moment().subtract(14, 'd').toDate();
}
//This Month
if (selectedOption == 10) {
return moment().startOf('month').toDate();
}
//Last 30 Days
if (selectedOption == 11) {
return moment().subtract(30, 'd').toDate();
}
//Last Month
if (selectedOption == 12) {
return moment().startOf('month').subtract(1,'M').toDate()
}
//Last 90 Days
if (selectedOption == 13) {
return moment().subtract(90, 'd').toDate();
}
}
function getToDate() {
//Today
if (selectedOption == 2) {
return new Date();
}
//Yesterday
if (selectedOption == 3) {
return moment().subtract(1, 'd').toDate();
}
//This Week (Sun - Today)
if (selectedOption == 4) {
return new Date();
}
//This Week (Mon - Today)
if (selectedOption == 5) {
return new Date();
}
//Last 7 Days
if (selectedOption == 6) {
return new Date();
}
//Last Week (Mon - Sunday)
if (selectedOption == 7) {
return moment().day(0).toDate();
}
//Last Business Week (Mon - Fri)
if (selectedOption == 8) {
return moment().day(-2).toDate();
}
//Last 14 days
if (selectedOption == 9) {
return new Date();
}
//This Month
if (selectedOption == 10) {
return moment().endOf('month').toDate();
}
//Last 30 Days
if (selectedOption == 11) {
return new Date();
}
//Last Month
if (selectedOption == 12) {
return moment().subtract(1, 'M').endOf('month').toDate();
}
//Last 90 Days
if (selectedOption == 13) {
return new Date();
}
}
关于javascript - 如何使用 HTML/JS 实现 'human' 日期范围选择下拉列表? (今天、昨天、上周……),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32498397/
我正在学习构建单页应用程序 (SPA) 所需的所有技术。总而言之,我想将我的应用程序实现为单独的层,其中前端仅使用 API Web 服务(json 通过 socket.io)与后端通信。前端基本上是
当我看到存储在我的数据库中的日期时。 这是 正常 。日期和时间就是这样。 但是当我运行 get 请求来获取数据时。 此格式与存储在数据库 中的格式不同。为什么会发生这种情况? 最佳答案 我认为您可以将
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试使用backbone.js 实现一些代码 和 hogan.js (http://twitter.github.com/hogan.js/) Hogan.js was developed ag
我正在使用 Backbone.js、Node.js 和 Express.js 制作一个 Web 应用程序,并且想要添加用户功能(登录、注销、配置文件、显示内容与该用户相关)。我打算使用 Passpor
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我尝试在 NodeJS 中加载数据,然后将其传递给 ExpressJS 以在浏览器中呈现 d3 图表。 我知道我可以通过这种方式加载数据 - https://github.com/mbostock/q
在 node.js 中,我似乎遇到了相同的 3 个文件名来描述应用程序的主要入口点: 使用 express-generator 包时,会创建一个 app.js 文件作为生成应用的主要入口点。 通过 n
最近,我有机会观看了 john papa 关于构建单页应用程序的精彩类(class)。我会喜欢的。它涉及服务器端和客户端应用程序的方方面面。 我更喜欢客户端。在他的实现过程中,papa先生在客户端有类
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我是一个图形新手,需要帮助了解各种 javascript 2D 库的功能。 . . 我从 Pixi.js 中得到了什么,而我没有从 Konva 等基于 Canvas 的库中得到什么? 我从 Konva
我正在尝试将一些 LESS 代码(通过 ember-cli-less)构建到 CSS 文件中。 1) https://almsaeedstudio.com/ AdminLTE LESS 文件2) Bo
尝试查看 Express Passport 中所有登录用户的所有 session ,并希望能够查看当前登录的用户。最好和最快的方法是什么? 我在想也许我可以在登录时执行此操作并将用户模型数据库“在线”
我有一个 React 应用程序,但我需要在组件加载完成后运行一些客户端 js。一旦渲染函数完成并加载,运行与 DOM 交互的 js 的最佳方式是什么,例如 $('div').mixItUp() 。对
请告诉我如何使用bodyparser.raw()将文件上传到express.js服务器 客户端 // ... onFilePicked(file) { const url = 'upload/a
我正在尝试从 Grunt 迁移到 Gulp。这个项目在 Grunt 下运行得很好,所以我一定是在 Gulp 中做错了什么。 除脚本外,所有其他任务均有效。我现在厌倦了添加和注释部分。 我不断收到与意外
我正在尝试更改我的网站名称。找不到可以设置标题或应用程序名称的位置。 最佳答案 您可以在 config/ 目录中创建任何文件,例如 config/app.js 包含如下内容: module.expor
经过多年的服务器端 PHP/MySQL 开发,我正在尝试探索用于构建现代 Web 应用程序的新技术。 我正在尝试对所有 JavaScript 内容进行排序,如果我理解得很好,一个有效的解决方案可以是服
我是 Nodejs 的新手。我在 route 目录中有一个 app.js 和一个 index.js。我有一个 app.use(multer....)。我还定义了 app.post('filter-re
我正在使用 angular-seed用于构建我的应用程序的模板。最初,我将所有 JavaScript 代码放入一个文件 main.js。该文件包含我的模块声明、 Controller 、指令、过滤器和
我是一名优秀的程序员,十分优秀!