2021-11-10

本文介绍了JavaScript在发送AJAX请求时可以使用绝对路径或相对路径,并强调了相对路径可能导致的不同服务器访问结果。同时,阐述了浏览器跨域访问的概念,以及三种实现JS跨域的方法:基于iframe、script标签(利用JSONP)和后台处理方式。
摘要由CSDN通过智能技术生成

1.JavaScript在发送AJAX请求时,URL的域名地址是使用绝对路径还是相对路径?

使用相对地址和绝对地址发送Ajax请求都可以。两者在发送请求时,服务器访问的地址都会转化为绝对地址。如果使用相对地址的话,要注意填写正确,不然可能导致服务器访问的地址不是目的地址。例如使用"login.java",服务器访问的可能是"http://localhost:8080/web/login.java"。而"/test/login.java",服务器访问的可能是"http://localhost:8080/test/login.java"。最终访问到的结果不同。

 

2.什么是浏览器跨域访问操作,js如何实现?

浏览器从一个域名的网页去请求一个域名的资源时,域名、端口、协议任一不同,都是跨域。

 
三种方法实现js跨域访问:

1.基于iframe实现跨域。基于iframe跨域要求两个页面必须属于一个基础域,使用同一协议和同一端口。

2.基于script标签实现跨域。通过动态创建script标签就可以加载其它域的js文件,然后通过本页面就可以调用加载后js文件的函数,这样做的缺陷就是不能加载其它域的文档,只能是js文件,jsonp便是通过这种方式实现的,jsonp通过向其它域传入一个callback参数,通过其他域的后台将callback参数值和json串包装成javascript函数返回,因为是通过script标签发出的请求,浏览器会将返回来的字符串按照javascript进行解析执行,实现了域与域之间的数据传输。

3.后台处理方式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值