537day(ajax-fn1.html)

本文介绍了一个AJAX请求的封装方法,包括GET和POST请求的处理,展示了如何将对象类型的参数转换为URL参数形式,并提供了具体的使用示例。

《2019年3月25日》【连续 537天】

标题:ajax-fn1.html;
内容:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>关于AJAX的封装</title>
</head>
<body>
  <script>

    // 封装的套路:
    // 1. 写一个相对比较完善的用例
    // 2. 写一个空函数,没有形参,将刚刚的用例直接作为函数的函数体
    // 3. 根据使用过程中的需求抽象参数
    //


    // // ## version 4 ========================================
    // function ajax (method, url, params) {
    //   var res = null

    //   method = method.toUpperCase()
    //   var xhr = new XMLHttpRequest()

    //   // 将 object 类型的参数转换为 key=value&key=value
    //   if (typeof params === 'object') {
    //     var tempArr = []
    //     for (var key in params) {
    //       var value = params[key]
    //       tempArr.push(key + '=' + value)
    //     }
    //     // tempArr => [ 'key1=value1', 'key2=value2' ]
    //     params = tempArr.join('&')
    //     // params => 'key1=value1&key2=value2'
    //   }

    //   if (method === 'GET') {
    //     url += '?' + params
    //   }

    //   xhr.open(method, url, false)

    //   var data = null
    //   if (method === 'POST') {
    //     xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')
    //     data = params
    //   }

    //   xhr.onreadystatechange = function () {
    //     if (this.readyState !== 4) return
    //     // 不应该在封装的函数中主观的处理响应结果
    //     // console.log(this.responseText)
    //     // 无法再内部包含的函数中通过 return 给外部函数的调用返回结果
    //     // return this.responseText
    //     // 由于异步模式下 这里的代码最后执行 所以不可能在外部通过返回值的方式返回数据
    //     res = this.responseText
    //   }

    //   xhr.send(data)

    //   return res
    // }

    // ajax('GET', 'time.php', { id: 1 })
    // ajax('POST', 'add.php', { key1: 'value1', key2: 'value2' })
    // ajax('POST', 'add.php', 'key1=value1')
    // ajax('post', 'add.php', 'key1=value1')

    // var res = ajax('GET', 'time.php', { id: 1 })
    // console.log(res)

    // var res1 = ajax('GET', 'time.php', { id: 1 })
    // console.log(res1)


  </script>
</body>
</html>

 

<think>好的,我现在要解释这段C#代码:DateTime.Today.AddDays(-1*(DateTime.Today.Day-1)).AddMonths(-1).ToString("yyyy-MM-dd")。首先,我需要拆解每一部分的含义,逐步分析每个方法的作用。 首先,DateTime.Today获取的是当前日期,不包括时间部分。比如今天是2023-10-05,那么DateTime.Today就是2023-10-05。接下来是AddDays方法,参数是-1乘以(当前日期的天数减1)。比如,今天如果是5号,那么Day属性是5,减1得到4,再乘以-1就是-4。所以AddDays(-4)会将日期减去4天,得到2023-10-01。这一步的作用应该是将日期调整到当月的第一天。接下来是AddMonths(-1),这会在上一步得到的当月第一天基础上再减去一个月。例如,如果上一步得到的是2023-10-01,减去一个月就是2023-09-01。这样,整个表达式的结果就是上个月的第一天。最后,ToString("yyyy-MM-dd")将日期格式化为字符串,如“2023-09-01”。所以整个代码的作用是获取上个月第一天的日期,并格式化为指定格式的字符串。 不过,我需要验证一下是否正确。比如,如果今天是当月的第一天,比如2023-11-01,那么Day1,计算AddDays的参数是-1*(1-1)=0,所以AddDays(0)不会改变日期,仍然是111日。然后AddMonths(-1)就变成了10月1日,正确。 再考虑月末的情况,比如2023-02-28(非闰年),那么AddDays(-27)会把日期变为2月1日,再减去一个月得到11日,没错。 那如果当前日期是某个月的最后一天,比如3月31日,那么Day是31,AddDays(-30)得到3月1日,再减去一个月就是2月1日,没问题。但如果是像3月30日这样的情况,同样适用,因为无论当前是几号,都减去Day-1天,回到当月第一天,再减去一个月。所以整个逻辑是正确的,这段代码确实可以获取上个月第一天的日期。</think>这段C#代码用于获取上个月第一天的日期并格式化为"yyyy-MM-dd"格式: ```csharp DateTime.Today.AddDays(-1*(DateTime.Today.Day-1)).AddMonths(-1).ToString("yyyy-MM-dd") ``` 代码解释分步说明: 1. `DateTime.Today`:获取当前日期(不含时间部分) 2. `DateTime.Today.Day-1`:计算当前日期距离本月第一天过了多少天 3. `-1*(...)`:将天数差转为负数,用于回退天数 4. `.AddDays(...)`:将日期回退到本月第一天 5. `.AddMonths(-1)`:再往前推一个月,得到上个月第一天 6. `.ToString("yyyy-MM-dd")`:格式化为年--日字符串 示例(假设当前日期是2023-10-15): 1. 当前日期:2023-10-15 2. Day-1 = 15-1 = 14 3. 回退14天:2023-10-01 4. 回退1个月:2023-09-01 5. 格式化输出:"2023-09-01"
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值