1、Ajax、get、post、ajax,随机颜色

一、Ajax初始

1、什么是Ajax?

  • 异步的JavaScript和xml

2、xml是什么?

  • 一种标记语言,传输和存储数据----------现在用JSON传输数据

3、Ajax的作用

局部加载
可以使网页异步更新

4、Ajax的原理或者步骤(6步)

  • 创建Ajax对象
if (window.XMLHttpRequest) {
    var xhr = new XMLHttpRequest()
    console.log(xhr, typeof xhr, xhr instanceof Object);
} else {
//iE6以下
    var xhr = new ActiveXObject()
}
  • 设置请求的方式、地址、是否异步
xhr.open('get', './数据', true)
  • 向后端发起请求
xhr.send()
  • 后端接收数据
xhr.onreadystatechange = function () {
  console.log(xhr)
}
  • 后端进行数据判断
  if(xhr.readyState == 4 && xhr.status == 200) {
    console.log("请求成功!")
}
  • 将成功后的数据返回给前端,并进行渲染
document.getElementByTagName('h1')[0].innerText = xhr.responseText

5、地址栏传参实例

地址栏传参query: url?参数=+具体的值

//1、创建Ajax对象
if (window.XMLHttpRequest) {
  var xhr = new XMLHttpRequest()
} else {
    //iE6以下
  var xhr = new ActiveXObject()
}
console.log(str)
// 2、设置请求的方式、地址、是否异步
/*-------------地址栏传参query: url?参数=+具体的值------------*/
xhr.open('get', './getHead.php?q=' + str, true)
// 3、向后端发起请求
xhr.send()
// 4、后端接收数据
xhr.onreadystatechange = function () {
// 5、后端进行数据判断
  if (xhr.readyState == 4 && xhr.status == 200) {
// 6、将成功后的数据返回给前端,并进行渲染
    console.log(xhr)
    document.getElementById('result').innerHTML = xhr.response
  }
}
image-20240304114604797

6、请求体传参

请求体传参body:“参数=”+具体的值
JSON字符串转JSON对象

json字符串转json对象:JSON.parse(json对象)
var obj = JSON.parse(xhr.response)

字符串转json对象:JSON.parse(json对象)

  • application/x-www-form-urlencoded 表单的格式
  • application/json json的格式 (默认的)
var user = document.getElementById('user')
var pwd = document.getElementById('pwd')
function login() {
    //1、创建Ajax对象
  if (window.XMLHttpRequest) {
    var xhr = new XMLHttpRequest()
  } else {
    var xhr = ActiveXObject()
  }
  xhr.open('post', '../tt_post.php', true)
// 请求体传参在传递之前必须设置请求头,如果不设置就是默认的
// setRequestHeader('Content-Type', '类型的值')
/* 
  application/x-www-form-urlencoded   表单的格式
  application/json   json的格式 (默认的)
*/
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')
xhr.send('username=' + user.value + '&password=' + pwd.value)
  xhr.onreadystatechange = function () {
    if (xhr.readyState == 4 && xhr.status == 200) {
      console.log(xhr)
      console.log(xhr.response)
      console.log(typeof xhr.response)
    // JSON字符串转JSON对象
      var obj = JSON.parse(xhr.response)
      console.log(obj)
      document.getElementById('result').innerHTML =
      '<p>' + obj.username + '</p><p>' + obj.password + '</p>'
    }
  }
}
image-20240304114517849

二、$.get方法请求数据

  • 一般的get请求都是地址栏传参
  • $.get(url,function(data,stutas){}) 只能运用get请求
  • data:返回的数据
  • stutas:状态 成功success 失败error
<body>
  <h1>在输入框中尝试输入字母 a:</h1>
  <form action="">
    <label for="">请输入:</label>
    <input type="text" id="valueText" />
  </form>
  <p>
    <span>提示信息:</span>
    <b id="result"></b>
  </p>
</body>
$('#valueText').keyup(function () {
  $.get('getHead.php?q=' + $(this).val(), function (data, stutas) {
    // console.log(stutas)
    if (stutas == 'success') {
      // console.log(data)
      $('#result').text(data)
    }
  })
})         

三、$post方法请求数据

  • $.post(url,params,function(data,stutas){}) 只能运用于post请求
  • url:请求的地址
  • params:请求的参数
  • data:返回的数据
  • stutas:状态
<body>
  <form action="" method="get">
    <div>
      <label for="">姓名:</label>
      <input type="text" id="user" />
    </div>
    <div>
      <label for="">密码:</label>
      <input type="password" id="pwd" />
    </div>
  </form>
  <button>登录2343434344</button>
  <div id="result"></div>
</body>
<script>
  $('button').click(function () {
    $.post(
      './tt_post.php',
      'username=' + $('#user').val() + '&password=' + $('#pwd').val(),
      function (data, stutas) {
        if (stutas == 'success') {
          $('#result').html('<p>' +JSON.parse(data).username +'</p><p>'            +JSON.parse(data).password +'</p>'
          )
        }
      }
    )
  })
  </script>

四、$.ajax方法请求数据

$.ajax({
   url: './tt_post.php', //请求的地址,
   type: 'POST', //请求的方式
   async: true, //是否异步
   headers: {
     'Content-type': 'application/x-www-form-urlencoded',
   }, //请求头
   data: {
     username: $('#user').val(),//获取输入框的值
     password: '1243',
   }, //参数
   success: function (res) {
     console.log(res) //返回的数据
   }, //成功后
   error: function (err) {
     console.log(err) //Ajax对象
   }, //失败后
   complete: function (data) {
     console.log(data) //Ajax对象
   }, //都会执行完成的方法
}) 

五、get请求和post请求的区别?

image-20240304163333417

六、随机颜色

function changeColor() {
  var red = Math.floor(Math.random() * 256);
  var green = Math.floor(Math.random() * 256);
  var blue = Math.floor(Math.random() * 256);
  var color = 'rgb(' + red + ', ' + green + ', ' + blue + ')';
    return color;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/431033.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

centos 搭建ftp服务器

项目上需要用到ftp文件服务同步&#xff0c;所以在测试环境进行搭建&#xff0c;其中遇到了一些问题&#xff0c;遂记录。 1、安装vsftpd软件包 打开终端并输入以下命令来安装vsftpd yum install vsftpd -y 2、运行vsftpd systemctl start vsftpd 3、测试匿名连接 我这里…

基于springboot+vue的球队训练信息管理系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

【OBS】obs-websocket实战技巧,让你更快的了解OBS

▒ 目录 ▒ &#x1f6eb; 导读开发环境 1️⃣ 修改OBS-web源码2️⃣ 常用api汇总获取输入源类型列表获取输入源列表获取属性列表打开输入源属性设置框获取设置输入源静音状态获取特殊输入源设置&#xff08;全局音频设备&#xff09;打开输入源属性设置框 &#x1f6ec; 文章小…

HubSpot出海CRM可以为企业带来哪些好处?

HubSpot出海CRM为企业带来了许多好处&#xff0c;包括但不限于以下几点&#xff1a; 优化客户体验&#xff1a; HubSpot出海CRM提供了个性化的客户关系管理功能&#xff0c;使企业能够根据客户的地理位置、偏好和行为等因素&#xff0c;提供个性化的营销和服务。这有助于提高客…

数位dp 笔记

小技巧1:求区间[X, Y]可以转换为求F(Y) - F(X-1) F(X)表示0~X中满足条件的数字个数 小技巧2&#xff1a;可以用树的形式来看 遍历最高位&#xff0c;每一位分为两种情况&#xff1a;未达到上界和达到上界 如果走到右边最底端需加1 度的数量 求给定区间 [X,Y]中满足下列条件的…

linux系统UDP丢包问题分析思路

Linux系统UDP丢包 最近工作中遇到某个服务器应用程序 UDP 丢包&#xff0c;在排查过程中查阅了很多资料&#xff0c;总结出来这篇文章&#xff0c;供更多人参考。 在开始之前&#xff0c;我们先用一张图解释 linux 系统接收网络报文的过程。  1&#xff0c;首先网络报文通过物…

软件测试--性能测试工具JMeter

软件测试--性能测试工具JMeter 主流性能测试工具1.主流性能测试工具Loadrunner和Jmeter对比 —— 相同点2.主流性能测试工具Loadrunner和Jmeter对比 —— 不同点JMeter基本使用JMeter环境搭建1.安装JDK:2.安装Jmeter:3.注意点:JMeter功能概要1. JMeter文件目录介绍1.1 bin目…

JavaScript的`call`方法:实现函数间的调用!

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

express+mysql+vue,从零搭建一个商城管理系统10--添加商品

提示&#xff1a;学习express&#xff0c;搭建管理系统 文章目录 前言一、新建models/goods.js二、新建routes/goods.js三、添加goods表四、添加商品总结 前言 需求&#xff1a;主要学习express&#xff0c;所以先写service部分 一、新建models/goods.js models/goods.js con…

亚马逊卖家做市场分析业务可以用静态IP代理完成吗?

亚马逊作为全球最大的电商平台之一&#xff0c;其庞大的销售数据和用户行为数据成为了许多商家和市场研究人员进行市场分析和竞争研究的重要来源。而使用IP代理则能够为亚马逊市场分析带来许多帮助&#xff0c;下面就来一一介绍。静态IP代理可以为市场分析带来哪些帮助&#xf…

高维中介数据: 联合显着性(JS)检验法

摘要 中介分析在流行病学和临床试验中越来越受到关注。在现有的中介分析方法中&#xff0c;流行的联合显着性&#xff08;JS&#xff09;检验会产生过于保守的 I 类错误率&#xff0c;因此功效较低。但是&#xff0c;如果在使用 JS 测试高维中介假设时&#xff0c;可以准确控制…

表达式和语句

本文参考C Primer Plus进行C语言学习 文章目录 表达式语句 副作用和序列点复合语句&#xff08;块&#xff09;类型转换 1.表达式 表达式由运算符和运算对象组成。下面是一些表达式&#xff1a; 4 -6 421 a*&#xff08;bc/d&#xff09;/20 q5*2 xq%3 q>3 每个表达式都有一…

基于带时间窗口的电动汽车路由问题的精英对立学习的多群PSO(2022)

英文&#xff1a;Multi-swarm PSO based on Elite Opposite Learning on Electric Vehicle Routing Problem with Time Window 摘要&#xff1a; 带时间窗口的电动汽车路由问题&#xff08;EVRPTW&#xff09;是交通领域的一个新问题&#xff0c;用传统的精确求解方法很难解决…

vue3.0源码解析之数据代理Proxy

前言 多年前刚转前端的时候&#xff0c;对频繁的拼接页面元素深恶痛绝&#xff0c;当时是通过封装字符串模版来处理页面的。之后又陆续发现&#xff0c;数据变化后需要频繁的修改dom节点来操作页面&#xff0c;便不得不自己写很多更新的代码&#xff0c;直到出现了vue和react、…

【排序】详解堆排序

一、思想 堆排序是一种基于比较的排序算法&#xff0c;且使用了堆的数据结构来辅助进行排序。其思想是利用堆的特性&#xff0c;即在每个节点都保证是最大&#xff08;大顶堆&#xff09;或者最小&#xff08;小顶堆&#xff09;的关键码。具体原理和步骤如下&#xff1a; 构…

基于SpringBoot的论坛系统(附项目源码+论文)

摘要 如今的时代&#xff0c;是有史以来最好的时代&#xff0c;随着计算机的发展到现在的移动终端的发展&#xff0c;国内目前信息技术已经在世界上遥遥领先&#xff0c;让人们感觉到处于信息大爆炸的社会。信息时代的信息处理肯定不能用之前的手工处理这样的解决方法&#xf…

最值得入手的五款骨传导耳机,六大专业的选购技巧

亲爱的小伙伴们&#xff0c;你们是否曾因长时间戴着耳机而感到耳朵不适&#xff0c;比如耳朵闷痛、发痒&#xff0c;甚至出现异味&#xff1f;现在有一种耳机可以帮你解决这些问题&#xff0c;它就是骨传导耳机。这种耳机的设计避免了传统入耳式耳机可能带来的堵塞感和细菌滋生…

【prompt五】CoCoOP:Conditional Prompt Learning for Vision-Language Models

motivation 随着像CLIP这样强大的预训练视觉语言模型的兴起,研究如何使这些模型适应下游数据集变得至关重要。最近提出的一种名为上下文优化(CoOp)的方法将提示学习(nlp的最新趋势)的概念引入视觉领域,以适应预训练的视觉语言模型。具体来说,CoOp将提示中的上下文单词转换为…

Golang 程序启动原理详解

一.编译 go源代码首先要通过 go build 编译为可执行文件,然后去机器上直接执行的&#xff0c;在 linux 平台上为 ELF 格式的可执行文件&#xff0c;linux 能直接执行这个文件,而编译阶段会经过编译器、汇编器、链接器三个过程最终生成可执行文件 编译器&#xff1a;*.go 源码通…

数字逻辑与计算机组成

冯诺依曼计算机 计算机结构 计算机特点 1.采用二进制 2.程序存储 2.由五大部件组成计算机系统&#xff1a;运算器、存储器、控制器、输入设备和输出设备 计算机硬件系统的层次 中央处理器&#xff08;CPU&#xff09;&#xff1a;运算器 控制器 计算机主机&#xff1a;…