JavaScript在发送AJAX请求时,URL的域名地址是使用绝对地址还是相对地址?什么是浏览器跨域访问操作,JS如何实现?
JavaScript在发送请求时,URL的域名地址是使用相对路径,若使用绝对路径将会报错。这是由于浏览器的同源策略导致的。默认情况下,JavaScript在发送Ajax请求时,URL的域名必须和当前页面完全一致。
浏览器的跨域访问操作,简单来讲,就是这个页面的JavaScript代码要访问另一个页面,比如提交内容获取内容。由于安全原因,跨域访问被浏览器默认禁止。JS可通过三种方法实现跨域访问:
1.基于iframe实现跨域访问:
基于iframe实现的跨域两个页面必须属于一个基础域,使用同一协议和同一端口,这样在两个页面中同时添加document.domain,就可以实现父页面调用子页面的函数,从而实现跨域访问。
2.基于script标签实现跨域:
scrip标签不受浏览器同源策略的限制,它本身具有访问其他域的资源的功能。可以通过在页面动态创建script标签实现跨域访问。
3.后台代理方式:
将后台作为代理,每次对其它域的请求转交给本域的后台,本域的后台通过模拟http请求去访问其它域,再将返回的结果返回给前台,无论访问的是文档,还是js文件都可以实现跨域。