allantatter/laravel-react 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

allantatter/laravel-react

最新稳定版本:v0.1.0

Composer 安装命令:

composer require allantatter/laravel-react

包简介

Render React.js components seemlessly on the server side within Laravel Blade views.

README 文档

README

Laravel React

Build Status Total Downloads Latest Stable Version Latest Unstable Version License

Add React.js support seamlessly for Laravel Blade templates.

Installation

Add this to your project's composer.json

"require": {
	"allantatter/laravel-react": "0.1.*"
},

Then run

$ composer update

Service provider & alias

Add this to the providers array in config/app.php

'AllanTatter\React\ReactServiceProvider',

Add this to the aliases array in config/app.php

'React' => 'AllanTatter\React\Facades\React',

Setup server-rendering with Node.js application

In this repository, you'll find a directory named example and inside that is resources. Copy paste its content to your own project's resources directory and in addition to that merge the package.json file from example directory into your own project's package.json.

Then in your project's root dir, run

$ npm install -g nodemon

$ npm install
$ npm start

If you put server.js in another location, you may have to configure this line inside that file

require('dotenv').load({path: '../../.env'});

Usage

Inside your Blade view, you can render React component like this

{!! React::component('ComponentName', $props) !!}

To render react-router routes, you can use this

{!! React::router('routesFileName', $props) !!}

Configuration

If you're not happy with default configuration, you can manage a few variables through .env file, following are default values:

REACT_SERVER_URL=http://localhost
REACT_SERVER_PORT=3000
REACT_COMPONENTS_DIR=components
REACT_EXTENSION=jsx

Snippets that may come in handy

Handle 404 pages with react-router by rendering your react application with adding this snippet into app/Exceptions/Handler.php, method render()

if ($e instanceof \Symfony\Component\HttpKernel\Exception\NotFoundHttpException)
{
	return response(view('react.app.view'));
}

统计信息

  • 总下载量: 1.5k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 51
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 51
  • Watchers: 5
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-04-08