草庐IT

javascript - 带有事件 div 的自定义日历

coder 2024-07-15 原文

我正在开发一个事件系统,它基本上是一个高度为 720 像素的容器,每个像素代表从上午 9 点到晚上 9 点的一分钟,宽度为 620 像素(左右填充 10 像素)

日历系统的自然要求是:

  • 对象的布局应使它们在视觉上不会重叠。
  • 如果一个时间段内有一个事件,则其宽度为600px
  • 每个碰撞事件的宽度必须与其碰撞宽度的每个其他事件的宽度相同。
  • 事件应尽可能使用最大宽度,同时仍遵守第一个约束条件。

输入将是一个数组,类似于:

[
 {id : 1, start : 30, end : 150},  // an event from 9:30am to 11:30am
 {id : 2, start : 540, end : 600}, // an event from 6pm to 7pm
 {id : 3, start : 560, end : 620}, // an event from 6:20pm to 7:20pm
 {id : 4, start : 610, end : 670} // an event from 7:10pm to 8:10pm
]

我已经创建了所需的布局,但我仍然坚持使用 JavaScript 部分 :( 这是我目前所拥有的:

var Calendar = function() {

   var layOutDay = function(events) {
     var eventsLength = events.length;

     if (! eventsLength) return false;

     // sort events
     events.sort(function(a, b){return a.start - b.start;});

     for (var i = 0; i < eventsLength; i++) {
         // not sure what is next
     }         

   };

   return {
       layOutDay : layOutDay,
   }

}();

需要创建div并按照上述要求定位。

Please see JSBin demo.

任何帮助将不胜感激。

最佳答案

这是一个可行的解决方案:http://jsbin.com/igujil/13/edit#preview

如您所见,这不是一个容易解决的问题。让我向您介绍一下我是如何做到的。

标记为第 0 步 的第一步是确保事件按 ID 排序。当我们开始使用数据时,这将使我们的生活更轻松。

第 1 步是初始化二维时隙数组。对于日历中的每一分钟,我们将创建一个数组,其中将包含那一分钟内发生的事件。我们这样做...

第 2 步!您会注意到我添加了一个检查以确保事件在结束之前开始。有点防御性,但我的算法会在错误数据上陷入无限循环,所以我想确保事件有意义。

在此循环结束时,我们的时隙数组将如下所示:

0: []
1: []
...
30: [1]
31: [1]
...
(跳到一些有趣的数字)
540:[2]
560: [2,3]
610:[3,4]

我鼓励您添加 console.log(timeslots)如果您感到困惑/好奇,就在第 3 步之前。这是解决方案中非常重要的一部分,下一步要解释起来要困难得多。

第 3 步是我们解决日程安排冲突的地方。每个事件需要知道两件事:

  1. 最大冲突次数。
  2. 水平排序(这样冲突就不会重叠)。

(1) 很容易,因为我们的数据是如何存储的;每个时隙数组的宽度是事件的数量。例如,时间段 30 只有 1 个事件,因为事件 #1 是当时唯一的一个。然而,在时间段 560,我们有两个事件,因此每个事件(#2 和 #3)计数为 2。 (如果一行包含三个事件,则它们都将计数为三,依此类推。)

(2) 有点微妙。事件 #1 很明显,因为它可以跨越日历的整个宽度。事件 #2 将不得不缩小其宽度,但它仍然可以从左边缘开始。事件 #3 不能。

我们用一个我称为 next_hindex 的时隙变量来解决这个问题.它从 0 开始,因为默认情况下我们希望沿左边缘定位,但每次发现冲突时它都会增加。这样,下一个事件(我们冲突的下一个部分)将从下一个水平位置开始。

第 4 步要简单得多。宽度计算使用第 3 步中的最大冲突计数。例如,如果我们知道在 5:50 有 2 个事件,我们就知道每个事件必须是日历宽度的 1/2。 (如果我们有 3 个事件,每个都是 1/3,等等)x 位置的计算方法类似;我们乘以 hindex 是因为我们想抵消(冲突数量)事件的宽度。

最后,我们只创建了一个小 DOM,定位我们的事件 div,并设置随机颜色以便于区分它们。结果是(我认为)您正在寻找的。

如果您有任何问题,我很乐意回答。我知道这可能比您预期的代码更多(也更复杂),但要解决这个问题却出奇地复杂:)

关于javascript - 带有事件 div 的自定义日历,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10562711/

有关javascript - 带有事件 div 的自定义日历的更多相关文章

  1. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  2. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  3. ruby-on-rails - form_for 中不在模型中的自定义字段 - 2

    我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢

  4. ruby - 主要 :Object when running build from sublime 的未定义方法 `require_relative' - 2

    我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby​​1.9+ 关于ruby-主要:Objectwhenrun

  5. ruby - 在 Ruby 中有条件地定义函数 - 2

    我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin

  6. ruby - 定义方法参数的条件 - 2

    我有一个只接受一个参数的方法:defmy_method(number)end如果使用number调用方法,我该如何引发错误??通常,我如何定义方法参数的条件?比如我想在调用的时候报错:my_method(1) 最佳答案 您可以添加guard在函数的开头,如果参数无效则引发异常。例如:defmy_method(number)failArgumentError,"Inputshouldbegreaterthanorequalto2"ifnumbereputse.messageend#=>Inputshouldbegreaterthano

  7. ruby - 如何在 Grape 中定义哈希数组? - 2

    我使用Ember作为我的前端和GrapeAPI来为我的API提供服务。前端发送类似:{"service"=>{"name"=>"Name","duration"=>"30","user"=>nil,"organization"=>"org","category"=>nil,"description"=>"description","disabled"=>true,"color"=>nil,"availabilities"=>[{"day"=>"Saturday","enabled"=>false,"timeSlots"=>[{"startAt"=>"09:00AM","endAt"=>

  8. ruby - 获取模块中定义的所有常量的值 - 2

    我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c

  9. ruby-on-rails - Nokogiri:使用 XPath 搜索 <div> - 2

    我使用Nokogiri(Rubygem)css搜索寻找某些在我的html里面。看起来Nokogiri的css搜索不喜欢正则表达式。我想切换到Nokogiri的xpath搜索,因为这似乎支持搜索字符串中的正则表达式。如何在xpath搜索中实现下面提到的(伪)css搜索?require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(ABBlaCD3"HTML_END#my_blockisgivenmy_bl="1"#my_eqcorrespondstothisregexmy_eq="\/[0-9]+\/"#FIXMEThefoll

  10. ruby - 这两个 Ruby 类初始化定义有什么区别? - 2

    我正在阅读一本关于Ruby的书,作者在编写类初始化定义时使用的形式与他在本书前几节中使用的形式略有不同。它看起来像这样:classTicketattr_accessor:venue,:datedefinitialize(venue,date)self.venue=venueself.date=dateendend在本书的前几节中,它的定义如下:classTicketattr_accessor:venue,:datedefinitialize(venue,date)@venue=venue@date=dateendend在第一个示例中使用setter方法与在第二个示例中使用实例变量之间是

随机推荐