用豆瓣电影api的项目

电影列表组件渲染

步骤:
1. 发送Ajax请求 1.1 在组件的componentWillMount这个生命周期钩子中发送请求 1.2 发送ajax
XMLHttpRequest
jQuery
Fetch(不支持JSONP),但有个包可以fetch-jsonp在npm上找 2. 渲染 如果正在加载,显示spin 如果加载完毕,渲染电影列表 3. 点击不同类型,获取不同数据展示 3.1 在子组件通过componentWillReceiveProps(props){}钩子来接props变动的值 3.2 在路由的Route中,通过设置一个<Route path='/movie/:movieType' component={MovieList} />,:后面的就是这个key,可以通过props.match.params.movieType接收到 3.3 接收到值之后调用setState({ },()=>{ }), 赋予给私有属性,然后通过回调函数重新获取请求

电影详情渲染

1.	通过编程式导航this.props.history.push()
this.props.history.push(`movie/detail/${movieid}`) 2. 在占位的地方需要精确匹配
<Route path='/movie/:movieType' exact component={MovieList} />
<Route path='/movie/detail/:movieid' component={MovieDetail} /> 3. 在MovieDetail.js中,用props接收传来的id

注意:

1. 在jsx中写js代码,需要用{}包起来

fetch

百度fetch第一篇文章

fetchjsonp


getMovieDetail(movieId) {
const url = `${MovieApi.movieApi}subject/${movieId}`
console.log(url)
fetchJsonp(url)
.then(response => response.json())
.then(data => {
console.log(data)
this.setState({
isLoading: false,
movieInfo: data
})
})
}

返回上一页

onClick={()=>{this.goBack}}

goBack(){
this.props.history.goBack()
}

服务器代理(跨域)

实现步骤:

1.	写node开发web服务,供我们自己的浏览器访问,并且还要设置允许我们自家浏览器跨域请求

2.	在node中使用一个第三方包request,发送请求给豆瓣服务器,拿到服务器数据

3.	我们node服务器,把数据返回给自己浏览器

代码操作步骤

详情看:http://www.expressjs.com.cn/starter/generator.html

express应用生成器

1.	npm install express-generator -g

2.	express myapp

3.	cd myapp
npm install 4. set DEBUG=myapp & npm start 5. 然后就可以通过localhost:3000/ 访问了

生成之后装包

yarn add request --save

var request = require('request')

//跨域
app.all('/test', function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*");
res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS');
res.header("Access-Control-Allow-Headers", "X-Requested-With");
res.header('Access-Control-Allow-Headers', 'Content-Type');
next();
}); //加一个路由
app.get('/detail', (req, res) => {
const movieId = req.query.movieId
const url = `https://api.douban.com/v2/movie/subject/${movieId}`
request(url, (err, response, body) => {
// res.setHeader('Content-Type','application/json;charset=UTF-8')
// res.end(body)
res.send(body)
})
}) 传值方记得要用?拼接数据,服务端用query接

自己客户端的请求代码

    const url = `http://localhost:3000/detail?movieId=${movieId}`
fetch(url).then(response=>response.json()).then(data=>{
console.log(data)
this.setState({
isLoading: false,
movieInfo: data
})
})

相关的api

可以百度豆瓣api

in_theaters: `https://api.douban.com/v2/movie/in_theaters`

top250: `https://api.douban.com/v2/movie/top250`

coming_soon: `https://api.douban.com/v2/movie/coming_soon`

大概的结构

定义自己的私有属性或者继承父亲的
定义方法放到生命周期钩子上 import React, {Component} from 'react' export default class MovieList extends Component{
constructor(){
super()
this.states ={
movieType: 'in_theaters',
isLoading: true,
movieList: []
}
} componentWillMount(){
this.getMovieListByType()
} getMovieListByType(){ } render(){
return(
<div> </div>
)
}
}

code

import React, {Component} from 'react'
import MovieApi from '../../../config'
import fetchJsonp from 'fetch-jsonp'
import {Spin, Alert, Rate} from 'antd'
import '../../static/css/movie.css'
export default class MovieList extends Component{
constructor(){
super()
this.state = {
movieType: 'in_theaters',
isLoading: true,
movieList: []
}
} componentWillMount(){
this.getMovieListByType()
} componentWillReceiveProps(props){
this.setState({
isLoading: true,
movieType: props.match.params.movieType
},()=>{
this.getMovieListByType()
})
} getMovieListByType(){
const url = `${MovieApi.movieApi}${this.state.movieType}`
fetchJsonp(url).then(response=>response.json()).then(data=>{
this.setState({
isLoading: false,
movieList: data.subjects
})
}).catch(e => console.log(e))
} render(){
if(this.state.isLoading){
return (
<Spin tip="Loading...">
<Alert
message="加载中..."
description="正在拼命的加载中...请稍等..."
type="info"
/>
</Spin>
)
}else{
return(
<div style={{display:'flex',flexWrap:'wrap',textAlign:'center', justifyContent:'space-between'}}>
{this.state.movieList.map((item,key)=>{
return <div key={key} style={{marginBottom: '16px'}} className='item'>
<img src={item.images.medium}/>
<h4>{item.title}</h4>
<h4>电影类型:{item.genres.join(',')}</h4>
<h4>上映年份:{item.year}</h4>
<div>评分:<Rate disabled defaultValue={item.rating.average/2} /></div>
</div>
})}
</div>
)
} }
}

1.	fetch-jsonp
发送jsonp请求
yarn add fetch-jsonp --save

豆瓣项目(用react+webpack)的更多相关文章

  1. 部署React+webpack工程的步骤

    # 部署React+webpack工程的步骤ps:以Mac os系统做开发环境.因为npm现在使用灰常的慢,所以我使用淘宝境像cnpm. 1,准备工作: 先确保存已经安装了node.js: 2,文件部 ...

  2. react +webpack 配置px2rem

    项目背景需要适配ipad 以及手机端,这时候当然要告别刀耕火种时代啦(自己算rem),因为已经有成熟的工具啦,即px2rem(https://www.npmjs.com/package/px2rem) ...

  3. 真刀实战地搭建React+Webpack+Express搭建一个简易聊天室

    一.前面bb两句 因为自惭(自残)webpack配置还不够熟悉,想折腾着做一个小实例熟悉.想着七夕快到了,做一个聊天室自己和自己聊天吧哈哈.好了,可以停止bb了,说一下干货. 二. 这个项目能学到啥? ...

  4. 如何在react&webpack中引入图片?

    在react&webpack项目中需要引入图片,但是webpack使用的模块化的思想,如果不进行任何配置,而直接在jsx或者是css中使用相对路径来使用就会出现问题,在webpack中提供了u ...

  5. react+webpack 引入字体图标

    在使用react+webpack 构建项目过程中免不了要用到字体图标,在引入过程中报错,不能识别字体图标文件中的@符,报错 Uncaught Error: Module parse failed: U ...

  6. 用React & Webpack构建前端新闻网页

    这是一篇给初学者的教程, 在这篇教程中我们将通过构建一个 Hacker News 的前端页面来学习 React 与 Webpack. 它不会覆盖所有的技术细节, 因此它不会使一个初学者变成大师, 但希 ...

  7. 七天接手react项目 系列 —— react 脚手架创建项目

    其他章节请看: 七天接手react项目 系列 react 脚手架创建项目 前面我们一直通过 script 的方式学习 react 基础知识,而真实项目通常是基于脚手架进行开发. 本篇首先通过 reac ...

  8. 现有iOS项目集成React Native过程记录

    在<Mac系统下React Native环境搭建>配置了RN的开发环境,然后,本文记录在现有iOS项目集成React Native的过程,官方推荐使用Cocoapods,项目一开始也是使用 ...

  9. scss + react + webpack + es6

    scss + react + webpack + es6 写在前面: 刚学习完慕课网里的一个幻灯片案例,自己加了刚学的react,两者结合.首先让大家看看效果 点击此处 你可以先用纯js实现上面的效果 ...

  10. NodeJS + React + Webpack + Echarts

    最近画了个简单的前端图,使用百度的echarts,基于原来项目的NodeJS+React+Webpack框架.在此记录一下: 1.  在react里封装echarts组件,并调用后端API. (参考的 ...

随机推荐

  1. day35-2 类的三大特性---多态,以及菱形继承问题

    目录 菱形继承问题 经典类 新式类 菱形继承 大招 多态与多态性 多态 多态性 多态在Python中的体现 鸭子类型(重要) 结论 菱形继承问题 经典类 没有继承object类的就是经典类,只有Pyt ...

  2. freemarker使用map替换字符串中的值demo2

    package demo01; import java.io.IOException;import java.io.OutputStreamWriter;import java.io.StringWr ...

  3. [luogu2329 SCOI2005] 栅栏(二分+搜索)

    传送门 Solution 纯搜索80分,加二分90分,再补一个小剪枝满分qwq 真.小剪枝:如果下一个的需求和当前相同,那么不需要再次从头开始试(看代码就明白了233) Code #include & ...

  4. Spring Cloud-hystrix使用例子(七)

    继承方式 HystrixCommand public class UserSelectAllCommand extends HystrixCommand<List<User>> ...

  5. ionic3中使用自定义配置

    新工作接触了ionic,以前没用过,只是离职前短暂接触过类似的vuex,到需要修改公司项目的时候临时差什么学什么,其中一个是自定义配置项 配置是很常见的设置,之前用的thinkphp的配置很清晰,基本 ...

  6. Android 自己定义TextView 实现文本间距

    转载请标明出处: http://blog.csdn.net/u011974987/article/details/50845269: Android系统中TextView默认显示中文时会比較紧凑.不是 ...

  7. HDU 5186

    easy !! #include <iostream> #include <cstdio> #include <algorithm> #define LL __in ...

  8. Justinmind使用教程(1)——概述部分

    Justinmind(http://www.justinmind.com/),类似于Axure的一个原型设计工具.就眼下而言,最适合移动端进行原型设计的工具,预计抛开Axure几条街了,可是眼下国内站 ...

  9. 系统报 “client没有所需的特权” 的解决方法

    今在对服务端代码进行单元測试的时候.突然报出例如以下错误: client没有所需的特权 后经网上查找,相同的问题都是属于对C盘读写的问题.回忆自己的项目也须要对C盘进行创建文件夹和读写文件.故尝试运行 ...

  10. C# SortedDictionary&lt;TKey, TValue&gt; 类

    表示依据键进行排序的键/值对的集合. https://msdn.microsoft.com/zh-cn/library/f7fta44c.aspx