zoukankan      html  css  js  c++  java
  • ajax 基本的封装

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
    "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <title>Title</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)


    // ## version 1 =======================================
    // function ajax (method, url, params) {
    // var xhr = new XMLHttpRequest()
    // xhr.open(method, url)
    // xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')

    // params = params || null

    // xhr.send(params)
    // xhr.onreadystatechange = function () {
    // if (this.readyState !== 4) return
    // console.log(this.responseText)
    // }
    // }

    // // ## version 2 ========================================
    // function ajax (method, url, params) {
    // var xhr = new XMLHttpRequest()

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

    // xhr.open(method, url)

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

    // xhr.send(data)
    // xhr.onreadystatechange = function () {
    // if (this.readyState !== 4) return
    // console.log(this.responseText)
    // }
    // }

    // // ## version 3 ========================================
    // function ajax (method, url, params) {
    // 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)

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

    // xhr.send(data)
    // xhr.onreadystatechange = function () {
    // if (this.readyState !== 4) return
    // console.log(this.responseText)
    // }
    // }

    // ajax('GET', 'time.php', { id: 1 })
    // ajax('POST', 'add.php', { key1: 'value1', key2: 'value2' })
    // ajax('POST', 'add.php', 'key1=value1')
    </script>
    </body>
    </html>
  • 相关阅读:
    Pulp之四:其它应用样例(1)-一般的整数规划问题 (设置目标约束函数)
    Pulp之三:官网上的应用样例(4)-Blending Problem (混合问题)
    Pulp之三:官网上的应用样例(3)-Sudoku Problem by LP (数独问题)
    Pulp之三:官网上的应用样例(2)-A Set Partitioning Problem (集合划分问题)
    list转换dict的方式以及zip的用法
    Pulp之三:官网上的应用样例(1)-The_Whiskas_Problem (猫粮配料比例问题)
    Pulp之二:Pulp中几个重要的概念
    一个简单有趣的题(4个变量找出取走的数)
    Java之父 James Gosling 发表博文 《Too Soon》纪念乔布斯。
    第01课 OpenGL窗口(1)
  • 原文地址:https://www.cnblogs.com/lujieting/p/10291396.html
Copyright © 2011-2022 走看看