js原生代码 2017年09月22日09:31:38本篇文章

  原生JS实现日历组件的示例代码

  更新时间:2017年09月22日 09:31:38 作者:softbone

  本篇文章主要介绍了原生JS实现日历组件的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  想要实现的效果

  实现思路

  为了组件的可复用性,需要用面向对象的思想。

  每个日历组件都是一个日历对象,主要包括日期选择框,日期控制显示栏,还有日历格子,为了保持日期控制显示栏和日历格子日期同步变化js原生代码,日期控制栏和日历里面的每个格子都应该包含一个Date属性,点击日历里的格子,将格子存的Date属性作为函数参数,调用函数改变日期控制栏显示的时间。同理,日期控制栏时间变化时,也将Date属性作为参数调用函数,函数重新绘制日历格子。

  上码:

  <pre class="brush:js;">
function Calendar(parentId) {
this.parentElement = document.getElementById(parentId);
this.init();
}
Calendar.prototype = {
init: function() {

  1. this.contains = document.createElement("div");
  2. this.contains.onselectstart = function(){return false}; //让按钮点击时不会出现文字被选中的蓝色块
  3. this.dateInput = document.createElement("input");
  4. this.datePicker = document.createElement("div");
  5. this.showDateBar = document.createElement("div");
  6. this.dateBox = document.createElement("div");
  7. this.icon = document.createElement("i");
  8. this.contains.className = 'datepicker-container';
  9. this.dateInput.className = 'date-input';
  10. this.dateInput.readOnly = true;
  11. var parent = this;
  12. this.dateInput.onclick = function(event){
  13. parent.onDateInputClick(event); //点击日期选择框时显示日历格子
  14. };
  15. this.contains.onblur = function(){
  16. parent.datePicker.style.display = 'none';
  17. }
  18. this.datePicker.className = 'date-picker';
  19. this.datePicker.style.display = 'none';
  20. this.showDateBar.className = 'show-date';
  21. this.dateBox.className = 'date-box';
  22. this.icon.className = 'date-icon';
  23. this.icon.innerHTML = ''; //iconfont这里用的阿里图标,可以自行替换
  24. this.datePicker.appendChild(this.showDateBar);
  25. this.datePicker.appendChild(this.dateBox);
  26. this.contains.appendChild(this.dateInput);
  27. this.contains.appendChild(this.icon);
  28. this.contains.appendChild(this.datePicker);
  29. this.parentElement.appendChild(this.contains);

},
}
</pre>

  初始化日期控制栏:

<p><pre class="brush:js;">
drawShowDateBar: function(parentElement){

  1. var parent = this;
  2. var nowDate = new Date();
  3. parentElement.date = nowDate;
  4. var nowYear = nowDate.getFullYear();
  5. var nowMonth = nowDate.getMonth();
  6. var nowDay = nowDate.getDate();
  7. //showDateBar内容拼接
  8. var contentStr =''+nowYear+'年';
  9. for(var i=0;i
文章由官网发布,如若转载,请注明出处:https://www.veimoz.com/1801
0 评论
755

发表评论

!