###面向对象的方法实现万年历
实现思路:
   1.创建构造函数constructor
   ```
   function Calender(main){
        this.currentDate = new Date()
        this.main = main;
    }
   ```
   2.创建日历对象的prototype方法
   ```
   Calender.prototype = {
        constructor: Calender,
        //创建主体内容区域
        showMain:function(){},
        //创建标题头区域
        showHeader: function(){},   
        //创建week标题头
        showWeek: function(){}, 
        //创建容纳日期的容器
        showDate:function(){},
        //封装一个方法,待点击切换月份时,初始化页面
        showInit: function(){}
    };//对象结束
   ```
   3.实现思路:
      
``` ==> 创建日历对象的主体内容
       showMain:function(){
            var $t = this;//将this对象缓存到$t中,this指向Calender对象
            
            $t.main = document.createElement("main")
            document.body.appendChild($t.main);
            $t.main.style.width = "600px";
            $t.main.style.height = "600px";
            $t.main.style.backgroundColor = "gray";
            $t.main.style.margin = "50px auto";
            $t.main.style.borderRadius = '15px'
        }
```
``` ==> 创建标题头区域(包含切换按钮/年月)
       showHeader: function(){
            var $t = this;
            //左控制键
            var prevSpan = document.createElement('span')
            $t.main.appendChild(prevSpan)
            prevSpan.innerHTML = '<'
            
            //存放年月信息
            var span = document.createElement('span')
            $t.main.appendChild(span)
            
            //右控制键
            var nextSpan = document.createElement('span')
            $t.main.appendChild(nextSpan)
            nextSpan.innerHTML = '>'
            
            var allSpan = document.querySelectorAll('span')
            var month = $t.currentDate.getMonth() + 1
            var year = $t.currentDate.getFullYear()
            
            //设置左边年月信息
            span.innerHTML = year + '年' + month + '月'
            for(var i = 0; i < allSpan.length; i++) {
                var span = allSpan[i]
                //设置span的css样式
                span.style.display = 'inline-block'
                span.style.width = '33.3%';
                span.style.height = '100px'
                span.style.color = 'white'
                span.style.fontSize = '30px'
                span.style.textAlign = 'center'
                span.style.lineHeight = '100px'
                span.id = 'index' + i
                
                //为左右按键添加事件
                if(i==0 || i==2) {
                    span.onclick = function() {
                        month = $t.currentDate.getMonth()
                        year = $t.currentDate.getFullYear()
                        if(this.id == 'index0') {
                            month--
                        } else if(this.id == "index2") {
                            month++
                        }
                    //点击完重新设置当前月
                    $t.currentDate.setMonth(month)
                    //清空页面
                    document.body.innerHTML = ''
                    //重新布局
                    $t.showInit()
                    }
                }
            };      
        }
```
     
``` ==> 创建week标题头
      showWeek: function(){
            var $t = this;
            //创建table标签
            var table = document.createElement('table')
            $t.main.appendChild(table)
            table.style.width = '100%'
            //往表格里边添加一行
            var tr = table.insertRow()
            var weeks = ['日','一', '二', '三', '四', '五', '六' ]
            for(var i = 0; i < weeks.length; i++) {
                //往tr插入列
                var td = tr.insertCell()
                td.style.height = '50px'
                td.style.backgroundColor = 'goldenrod'
                td.style.textAlign = 'center'
                td.innerHTML = weeks[i]
            }
        },
```
     
```==> 创建容纳日期的容器
      showDate:function(){
            var $t = this;
            var table = document.createElement('table')
            $t.main.appendChild(table)
            table.style.width = '100%'
            
            //创建一个名言标签
            var  p = document.createElement("p")
            $t.main.appendChild(p)
            p.innerHTML = "每一天都是新的自己,怎么活,自己决定!"
            p.style.fontSize = "24px";
            p.style.width = "100%";
            p.style.height = "60px";
            p.style.lineHeight = "30px"
            p.style.textAlign = "center"
            p.style.color = "white"
            
            //创建日期容器
            for(var i = 0; i < 6; i++) {
                //创建6行
                var tr = table.insertRow()
                for(var k = 0; k < 7; k++) {
                    //每一行7格
                    var td = tr.insertCell()
                    td.style.height = '60px'
                    td.style.backgroundColor = 'orange'
                    td.style.textAlign = 'center'
                    td.style.fontSize = "20px"
                    var dayIndex = i * 7 + k
                    
                    //计算每一个格所对应的日期对象
                    var eachDate = getEveryDate(dayIndex)
                    //得到每一个日期的号数
                    td.innerHTML = eachDate.getDate()
                    
                    //获取当天日期的值,突出显示当天日期
                    var now = new Date()
                    var currentDay = now.getDate()
                    //console.log(currentDay)
                    if(eachDate.getMonth() == now.getMonth() && eachDate.getDate() ===currentDay)
                        td.style.backgroundColor = "aquamarine"
                    
                    //判断当前月和推算出来的日期的月份是否一样,不一样则代表不是当前月的日期,则把日期灰色显示
                    if(eachDate.getMonth() != $t.currentDate.getMonth()) {
                        td.style.backgroundColor = 'lightgray'
                        td.style.color = 'gray'
                    }
                }
            }
        },
```
``` ==> 封装一个方法,待点击切换月份时,初始化页面
      //封装一个方法,待点击切换月份时,初始化页面
        showInit: function(){
            var $t = this;
            $t.showMain()
            $t.showHeader()
            $t.showWeek()
            $t.showDate()
        }
```
     
```  ==> 对象实例化和初始化页面
        //实例化一个Calender对象
        var calender = new Calender()
    
        calender.showInit()//初始化页面
```
 
源代码地址:github地址==》https://github.com/Hasyou99/Calender

原生JS面向对象方法实现万年历的更多相关文章

  1. 原生JS面向对象思想封装轮播图组件

    原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...

  2. 原生js面向对象编程-选项卡(自动轮播)

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  3. 原生js面向对象编程-选项卡(点击)

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  4. JS面向对象方法(二) 面向对象方法实现橱窗式图面预览以及放大功能

     效果图: HTML结构如下: <div id="preview"> <div id="mediumDiv"> <img id=& ...

  5. 模板内部不支持原生js的方法?》》artTemplate模版方法注册window全部事件方法

    我的模板中出现了: {{parseInt(hasshakenum)}} 结果报错: Template Error resultPageTMP Render Error parseInt is not ...

  6. JS面向对象方法(一): 使用原生JS 实现导航栏下多级分类弹出效果

    利用二级菜单的onmouseover/out事件 重新构建一级菜单 ".hover" 样式类 代码如下: CSS部分: 在原来的目标:hover样式中 增加 .hover状态 li ...

  7. 原生js面向对象写法

    Mouse就是一个类,有自己的成员变量和成员方法,成员方法一定加上prototype,避免js原型的坑. var Mouse = function(id) { this.id = id; this.n ...

  8. 自己封装的一个原生JS拖动方法。

    代码: function drag(t,p){ var point = p || null, target = t || null, resultX = 0, resultY = 0; (!point ...

  9. 【方法】原生js实现方法ajax封装

    /* 参数说明* type[String] 请求方式('POST'或'GET') 默认设置'GET'方式* dataType[String] 获取到的后台数据格式 默认'JSON'格式* async[ ...

随机推荐

  1. android中include标签使用详解

    android中include标签是为了便于控件的覆用的一个很好解决方案.   但是也有一些需要注意的地方,下面是本人在项目中碰到过的一个问题,做此记录,便于以后查看.   include标签用法. ...

  2. php中require、require_once、include、include_once类库重复引入效率问题详解

    首先我详细说下这四个引入函数 include() 与require() 的功能相同 唯一不同:require()不管是否被执行,只要存在,php在执行前都会预引入,include()则是执行到该语句时 ...

  3. JavaScript(第三十三天)【总结:封装基础前端框架】

    源码地址:https://github.com/whisper540/Base

  4. JavaScript(第四天)【运算符】

    ECMA-262描述了一组用于操作数据值的运算符,包括一元运算符.布尔运算符.算术运算符.关系运算符.三元运算符.位运算符及赋值运算符.ECMAScript中的运算符适用于很多值,包括字符串.数值.布 ...

  5. Access数据库自动生成设计文档

    在做Access数据库设计时,常常直接在access文件中建表,建字段,然后写设计文档时,又得重新再写一遍字段和表间关系.其实access数据库自己就支持自动生成数据库文档. 操作方法如下: 数据库工 ...

  6. 【福大软工】 W班级总成绩排名3

    评分链接: alpha测试    软件产品案例分析 总分排名: 团队千帆竞发图 总结: 本次排名是alpha测试    软件产品案例分析 两次排名的汇总. 1.alpha测试小组评价: 听说:10篇冲 ...

  7. 20162302 实验一《Java开发环境的熟悉》实验报告

    实 验 报 告 课程:程序设计与数据结构 姓名:杨京典 班级:1623 学号:20162302 实验名称:Java开发环境的熟悉 实验器材:装有Ubuntu的联想拯救者80RQ 实验目的与要求:1.使 ...

  8. Markdown文本测试

    一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 1. 这是一 2. 这是二 这是无序符号 My Github 这是着重表示 这是斜体 一级粗体 二级斜体 cin >> a; c ...

  9. 基于Unity·UGUI实现的RecycleList循环列表UI容器

    在UI功能开发实践中,列表UI容器是我们经常使用一种UI容器组件.这种组件就根据输入的数据集合生成对应数据项目.从显示的方向来说,一般就分为水平排布和垂直排布的列表容器两种.列表容器为了在有限的界面空 ...

  10. Angular组件——组件生命周期(一)

    组件声明周期以及angular的变化发现机制 红色方法只执行一次. 变更检测执行的绿色方法和和组件初始化阶段执行的绿色方法是一个方法. 总共9个方法. 每个钩子都是@angular/core库里定义的 ...