type=“module“模式下的跨域问题

html中使用type="module"的模式引入Js文件会报跨域问题
<script type="text/javascript" src="a.js"></script>
<script type="text/javascript" src="b.js"></script>
<script type="module">
        import './c.js'
</script>

a.js和b.js引入均正常
在这里插入图片描述
在这里插入图片描述
c.js引入则提示跨域问题
在这里插入图片描述
在这里插入图片描述

原因:

正常情况下引入文件(通过file协议引入文件)是不受同源策略的影响的(也就是Sec-Fetch-Mode:no-cors)
type="module"的模式下Sec-Fetch-Mode:cors,也就是说收到了同源协议的影响,而同源协议就要求合适请求头中的Origin信息,file协议是无法实现的,所以改为用LiveSreve启动Html就好了。

启动LiveServe

访问a.js文件
在这里插入图片描述
访问c.js文件
在这里插入图片描述

参考地址:https://www.cnblogs.com/lishanlei/p/9327646.html
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值