关于ajax访问express服务器的跨域问题

在学习es6的时候用promise封装了一个ajax

<script type="text/javascript">
    function getNews(URL) {

        let promise = new Promise((resolve,reject)=>{
            //状态初始化
            //执行异步任务

            let xmlHttp = new XMLHttpRequest();//创建对象
            console.log(xmlHttp.readyState);//初始状态 为0 一步一步变为4
            // 绑定监听
            xmlHttp.onreadystatechange = ()=>{
                if(xmlHttp.readyState === 4) {//请求成功
                    if (xmlHttp.status == 200) {
                        console.log(xmlHttp.responseText);
                        //修改状态
                        resolve(xmlHttp.responseText);
                    } else {//请求失败
                        reject(`暂时没有新闻`);
                    }
                }
            }

            // open 设置请求的方式及url
            xmlHttp.open('GET',URL);
            xmlHttp.send();
        });

        return promise;

    }

    getNews('http://localhost:3000')
        .then(data=>{
            console.log(data);
        },err=>{
            console.log(err);
        })
</script>

用express写了个简单个服务器路由,端口3000,但是一直报错,原来是不能跨域,后来在网上找解决办法,看网上加了好多头,我只加了报错的哪一个就可以了,如下

let express = require('express');

let app = express();

app.get('/',(req,res)=>{
    res.header("Access-Control-Allow-Origin", "*");
    res.send('123');
})
app.listen(3000);

最后在浏览器端可以看到返回的123

 

转载于:https://www.cnblogs.com/czy960731/p/8514504.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值