angular2 jsonp跨域请求 express输出jsonp数据

坑了半天终于搞定了,看代码。html

前端部分代码前端

一、app.module.tsexpress

import {JsonpModule} from "@angular/jsonp";

二、须要调取数据的组件 jsonp.component.tsjson

import {Component} from "@angular/core";
import {Jsonp, URLSearchParams} from "@angular/http";
import 'rxjs/add/operator/map';
@Component({
    selector: "my-jsonp",
    templateUrl: "app/templates/tpl1.html"
})
export class AppComponent {
    constructor(public jsonp:Jsonp) {
        // 重点来了,url地址后面添加?callback=JSONP_CALLBACK
        let wikiUrl = 'http://localhost:3000/users?callback=JSONP_CALLBACK';
        // 也可以使用URLSearchParams()设置参数,这里只有一个参数,就写在url里面了。
        // 使用map().substribe()获取数据
        this.jsonp.get(wikiUrl)
            .map(res=> res.json())
            .subscribe((response) => {
                console.log(response);
            }, (error) => {
                console.error(error);
            });
    }
}

后台部分代码(express)
返回jsonp数据便可app

router.get('/', function(req, res, next) {
  // 使用jsonp
  res.jsonp({"name": "heping"});
});
相关文章
相关标签/搜索