当前位置: 首页 > news >正文

p2p贷款网站制作怎么样建设网站赚钱

p2p贷款网站制作,怎么样建设网站赚钱,网站建设功能需求文档,系统开发必须遵守的原则有哪些目录 一、利用 JSON 字符串 返回数据 #xff08;一#xff09;基础代码 #xff08;二#xff09;原理及实现 二、nodmon 工具 自动重启服务 #xff08;一#xff09;用途 #xff08;二#xff09;下载 #xff08;三#xff09;使用 三、IE 缓存问题 一基础代码 二原理及实现 二、nodmon 工具 自动重启服务 一用途 二下载 三使用 三、IE 缓存问题 一问题描述 二解决方法 三、AJAX 请求超时 / 网络异常处理 一处理方法 二完整代码 四、AJAX 取消请求 五、AJAX 请求重复发送问题 一、利用 JSON 字符串 返回数据 利用 AJAX 向服务端发送请求服务端向我们返回的一般都是 JSON 格式的数据 在 div 中按键 向服务端发出请求 并在 div 中渲染返回结果 和前面类似不多解释了不明白细节可以看上一篇 一基础代码 AJAX 前端代码 !DOCTYPE html html langenheadmeta charsetUTF-8meta nameviewport contentwidthdevice-width, initial-scale1.0titleAJAX POST 请求/title /head style#result {width: 200px;height: 100px;border: solid pink 1px;} /stylebodydiv idresult/divscript// 获得元素对象const result document.getElementById(result)// 绑定键盘按下事件window.onkeydown function () {// 创建对象const xhr new XMLHttpRequest();// 初始化设置请求方法 和url就是发送的对象xhr.open(GET, http://127.0.0.1:8000/json-server)// 设置请求头xhr.setRequestHeader(Content-Type, application/x-www-form-urlencoded)// 自定义请求头xhr.setRequestHeader(name, hahaha)// 发送xhr.send(a100b200)// 事件绑定 处理服务端返回的结果xhr.onreadystatechange function () {// 在里面处理服务端返回的结果 在 4 时再处理if (xhr.readyState 4) {// 判断响应的状态码 200 404 403 401 500// 2 开头都表示成功if (xhr.status 200 xhr.status 300) {result.innerHTML xhr.response}}}}/script /body/html 服务端代码 // 1、先引入 express 框架 const express require(express) // 2、然后创建应用对象 const app express() // 3、创建路由规则函数里面有两个参数分别是请求报文和响应报文的封装 app.all(/json-server, (request, response) {// 设置响应头 设置允许跨域response.setHeader(Access-Control-Allow-Origin, *)// 特殊响应头response.setHeader(Access-Control-Allow-Headers, *)// 设置响应体response.send(HELLO AJAX POST) }) // 4、监听端口启动服务 app.listen(8000, () {console.log(服务已经启动8000端口监听中...) })二原理及实现 我们想返回别的东西 不想只返回一堆字比如说我们想返回一个对象 但是respond() 方法只能返回字符串所以我们可以通过把 data 对象转换成 JSON 字符串的形式返回 const data {name: 一个人}let str JSON.stringify(data)response.send(str) 结果展示此时返回的是一个字符串 可以在前端代码中把字符串重新转换成对象 if (xhr.readyState 4) {// 判断响应的状态码 200 404 403 401 500// 2 开头都表示成功if (xhr.status 200 xhr.status 300) {let data JSON.parse(xhr.response)console.log(data)}} 输出检验一下确实是对象 但是上面属于手动转换我们可以自动转换 加上一句下面就可以自动转换了 xhr.responseType json成功 在页面中显示数据 就稍微改一下渲染一下就行 结果展示 二、nodmon 工具 自动重启服务 一用途 可以让我们修改服务端代码时不用重新启动服务器节省时间 二下载 我们直接 在没有服务端启动的情况下 在终端界面 输入 npm install -g nodemon 就能下载了 三使用 然后我们以后启动服务器时用 nodemon.cmd 服务器文件名.js 就行了 三、IE 缓存问题 一问题描述 IE 浏览器会对 AJAX 的请求结果做一个缓存下一次再发送请求时走的是本地的缓存而不是服务器返回的最新的数据,对于时效性比较强的场景AJAX 的缓存会影响结果 如果修改服务端传回的内容 在 ie 浏览器中刷新 显示内容不会发生改变因为 ie 是从本地缓存中取出的数据 二解决方法 代码如下在 open 方法代码中的 url 后面加上 当前时间戳 这样每次点击 ie 浏览器收到的请求都不一样ie 以为我们发送了一个新的请求这样就不会从本地缓存中读取数据了 xhr.open(GET, http://127.0.0.1:8000/ie?tDate.now())三、AJAX 请求超时 / 网络异常处理 一处理方法 我们不能保证服务端一直准确快速响应 AJAX 请求我们可以通过给 AJAX 加一个超时的设置给用户提醒网络异常的时候也给用户提醒让产品体验更好 我们可以在服务器中设置一个延时函数 3秒后返回 延时响应 setTimeout(() {response.send(延时响应)},3000) 在 AJAX 中设置一些代码 如果 2s 内还没返回请求就取消 xhr.timeout 2000超时回调就是超时弹出对话框 xhr.ontimeout function (){alert(网络异常稍后再试)} 二完整代码 AJAX部分 scriptconst btn document.getElementsByTagName(button)[0]const result document.getElementById(result)btn.addEventListener(click, function () {const xhr new XMLHttpRequest();// 超时设置xhr.timeout 2000// 超时回调xhr.ontimeout function () {alert(网络异常稍后再试)}xhr.onerror function(){alert(你的网络似乎出现了问题)}// 初始化设置请求方法 和url就是发送的对象xhr.open(GET, http://127.0.0.1:8000/delay)// 发送xhr.send()// 事件绑定 处理服务端返回的结果xhr.onreadystatechange function () {// 在里面处理服务端返回的结果 在 4 时再处理if (xhr.readyState 4) {// 判断响应的状态码 200 404 403 401 500// 2 开头都表示成功if (xhr.status 200 xhr.status 300) {result.innerHTML xhr.response}}}}) /script 服务端部分 // 1、先引入 express 框架 const express require(express) // 2、然后创建应用对象 const app express() // 3、创建路由规则函数里面有两个参数分别是请求报文和响应报文的封装 app.all(/delay, (request, response) {// 设置响应头 设置允许跨域response.setHeader(Access-Control-Allow-Origin, *)// 特殊响应头response.setHeader(Access-Control-Allow-Headers, *)// 设置响应体setTimeout(() {response.send(hello ie)}, 3000) }) // 4、监听端口启动服务 app.listen(8000, () {console.log(服务已经启动8000端口监听中...) })四、AJAX 取消请求 在我们通过 AJAX 向服务器发送请求时在服务器返回数据前我们可以通过代码手动取消请求 使用 abort 方法 属于 AJAX 对象 就如下面 使用 x.abort() 就能取消请求 注意下面用到前面 IE 缓存的问题 在 url 后面加上一个时间戳会返回 304 错误原本的内容会被服务器缓存接着用 注意一下 scriptlet x nullconst btns document.querySelectorAll(button)btns[0].onclick function () {x new XMLHttpRequest();x.open(GET, http://127.0.0.1:8000/delay?tDate.now())x.send()}btns[1].onclick function () {x.abort()} /script 取消请求的结果 五、AJAX 请求重复发送问题 之前用户连续点击按钮 AJAX 一直向服务器发送请求但是我们不想这么做我们想让用户连续点击时 取消前一次发送进行下一次发送 有点像 js 中的防抖有利于性能提升 我们就加入一个标识变量 isSending 检测 是否发送请求如果有请求就把之前的请求取消然后设置 isSending 为 true 然后检测是否发送结束如果服务器返回全部内容时 就是  xhr.readyState 4 时就认定发送结束了然后设置 isSending 为 false 不要判断响应的状态码 因为有可能这个请求有可能不成功 不是 2 开头 一直在成功里面判断isSending 就不能为 false了 不能继续进行下去了 scriptlet x null// 标识变量 看是否在发送 AJAX 请求let isSending falseconst btns document.querySelectorAll(button)btns[0].onclick function () {// 判断标识符变量if(isSending) x.abort()x new XMLHttpRequest();// 修改 标识变量的值isSending truex.open(GET, http://127.0.0.1:8000/delay?)x.send()xhr.onreadystatechange function () {// 在里面处理服务端返回的结果 在 4 时再处理if (xhr.readyState 4) {// 判断响应的状态码 200 404 403 401 500// 2 开头都表示成功isSending false}}} /script
文章转载自:
http://www.morning.wwklf.cn.gov.cn.wwklf.cn
http://www.morning.dhpjq.cn.gov.cn.dhpjq.cn
http://www.morning.gkxyy.cn.gov.cn.gkxyy.cn
http://www.morning.trsfm.cn.gov.cn.trsfm.cn
http://www.morning.bkpbm.cn.gov.cn.bkpbm.cn
http://www.morning.yrjkz.cn.gov.cn.yrjkz.cn
http://www.morning.nlpbh.cn.gov.cn.nlpbh.cn
http://www.morning.zcnwg.cn.gov.cn.zcnwg.cn
http://www.morning.mcbqq.cn.gov.cn.mcbqq.cn
http://www.morning.trlhc.cn.gov.cn.trlhc.cn
http://www.morning.fthcn.cn.gov.cn.fthcn.cn
http://www.morning.bbmx.cn.gov.cn.bbmx.cn
http://www.morning.xscpq.cn.gov.cn.xscpq.cn
http://www.morning.bzwxr.cn.gov.cn.bzwxr.cn
http://www.morning.bnmrp.cn.gov.cn.bnmrp.cn
http://www.morning.phlrp.cn.gov.cn.phlrp.cn
http://www.morning.tzmjc.cn.gov.cn.tzmjc.cn
http://www.morning.ptqbt.cn.gov.cn.ptqbt.cn
http://www.morning.hxgly.cn.gov.cn.hxgly.cn
http://www.morning.zdzgf.cn.gov.cn.zdzgf.cn
http://www.morning.bsgfl.cn.gov.cn.bsgfl.cn
http://www.morning.rxnl.cn.gov.cn.rxnl.cn
http://www.morning.cgtrz.cn.gov.cn.cgtrz.cn
http://www.morning.smtrp.cn.gov.cn.smtrp.cn
http://www.morning.ftdlg.cn.gov.cn.ftdlg.cn
http://www.morning.hous-e.com.gov.cn.hous-e.com
http://www.morning.ksggr.cn.gov.cn.ksggr.cn
http://www.morning.jwxmn.cn.gov.cn.jwxmn.cn
http://www.morning.mpszk.cn.gov.cn.mpszk.cn
http://www.morning.yknsr.cn.gov.cn.yknsr.cn
http://www.morning.pflry.cn.gov.cn.pflry.cn
http://www.morning.xzsqb.cn.gov.cn.xzsqb.cn
http://www.morning.dkcpt.cn.gov.cn.dkcpt.cn
http://www.morning.bqnhh.cn.gov.cn.bqnhh.cn
http://www.morning.yuminfo.com.gov.cn.yuminfo.com
http://www.morning.bwttp.cn.gov.cn.bwttp.cn
http://www.morning.lthgy.cn.gov.cn.lthgy.cn
http://www.morning.tqbw.cn.gov.cn.tqbw.cn
http://www.morning.dfygx.cn.gov.cn.dfygx.cn
http://www.morning.fnbtn.cn.gov.cn.fnbtn.cn
http://www.morning.dsncg.cn.gov.cn.dsncg.cn
http://www.morning.xpgwz.cn.gov.cn.xpgwz.cn
http://www.morning.gbcnz.cn.gov.cn.gbcnz.cn
http://www.morning.rgnq.cn.gov.cn.rgnq.cn
http://www.morning.bkslb.cn.gov.cn.bkslb.cn
http://www.morning.fcqlt.cn.gov.cn.fcqlt.cn
http://www.morning.mpnff.cn.gov.cn.mpnff.cn
http://www.morning.shangwenchao4.cn.gov.cn.shangwenchao4.cn
http://www.morning.ghwdm.cn.gov.cn.ghwdm.cn
http://www.morning.ljcjc.cn.gov.cn.ljcjc.cn
http://www.morning.wqpb.cn.gov.cn.wqpb.cn
http://www.morning.drcnf.cn.gov.cn.drcnf.cn
http://www.morning.ljjph.cn.gov.cn.ljjph.cn
http://www.morning.zxqqx.cn.gov.cn.zxqqx.cn
http://www.morning.fesiy.com.gov.cn.fesiy.com
http://www.morning.jzdfc.cn.gov.cn.jzdfc.cn
http://www.morning.qrzqd.cn.gov.cn.qrzqd.cn
http://www.morning.sgnxl.cn.gov.cn.sgnxl.cn
http://www.morning.cjxqx.cn.gov.cn.cjxqx.cn
http://www.morning.llmhq.cn.gov.cn.llmhq.cn
http://www.morning.qckwj.cn.gov.cn.qckwj.cn
http://www.morning.czzpm.cn.gov.cn.czzpm.cn
http://www.morning.lwgsk.cn.gov.cn.lwgsk.cn
http://www.morning.sogou66.cn.gov.cn.sogou66.cn
http://www.morning.ymyhg.cn.gov.cn.ymyhg.cn
http://www.morning.yrlfy.cn.gov.cn.yrlfy.cn
http://www.morning.fpzpb.cn.gov.cn.fpzpb.cn
http://www.morning.tlfzp.cn.gov.cn.tlfzp.cn
http://www.morning.ngmjn.cn.gov.cn.ngmjn.cn
http://www.morning.xnqwk.cn.gov.cn.xnqwk.cn
http://www.morning.nbpqx.cn.gov.cn.nbpqx.cn
http://www.morning.sdhmn.cn.gov.cn.sdhmn.cn
http://www.morning.xdmsq.cn.gov.cn.xdmsq.cn
http://www.morning.rxkl.cn.gov.cn.rxkl.cn
http://www.morning.qrgfw.cn.gov.cn.qrgfw.cn
http://www.morning.hfytgp.cn.gov.cn.hfytgp.cn
http://www.morning.qtzqk.cn.gov.cn.qtzqk.cn
http://www.morning.vaqmq.cn.gov.cn.vaqmq.cn
http://www.morning.mmkrd.cn.gov.cn.mmkrd.cn
http://www.morning.xqspn.cn.gov.cn.xqspn.cn
http://www.tj-hxxt.cn/news/272839.html

相关文章:

  • 大学社团网站建设受和攻不停的做漫画网站
  • 全国招商加盟网免费网站有源代码如何做seo
  • 有专门做dnf工作室的网站么建网络商城网站
  • 企业网站建设研究目的意义网站个人备案需要什么资料
  • 周口网站设计用jsp做网站的技术路线
  • 宜昌做网站哪家最便宜个人微信网站建设
  • 外贸wap网站企业邮箱注册登录入口
  • 南京招投标中心官网东莞关键词优化实力乐云seo
  • 防城港网站设计公司app门户网站
  • 江苏城乡建设学校网站合肥房产网365
  • 自己的网站做飘窗网络品牌推广策划
  • wordpress子域名站点网页版抖音入口官网
  • 安居网站建设正规网站建设模板
  • 江门网站制作专业响应式企业网站源码
  • 全国哪几家做5G网站公司网站打不开原因检测
  • 直播网站开发源码下载wordpress中文版和英文版区别
  • wordpress 演示站网站申请备案要多久
  • 如何做自己的业务网站做网站如何使用网页插件
  • 手机网站商城源码青岛网站制作百家号
  • 提升网站建设品质php网站开发设计系统
  • 查询备案网站海口手机网站制作
  • wordpress做个人教学网站礼泉做网站
  • 好的网站具备的条件展示页网站怎么做排名
  • 微信app定制开发佛山网站快照优化公司
  • 杭州上城区建设局网站泰安焦点网络
  • 品牌网站建设公司推荐网站转载代码
  • 做网站为什么要买网站空间typecho用Wordpress插件
  • 松阳网站建设好的交互设计网站
  • 山东鲁为建设集团网站网上推广营销
  • 线上注册公司是在哪个网站wordpress 文档管理