npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

similar-react-router

v0.2.0

Published

similar react-router

Downloads

8

Readme

similar-react-router

Version Downloads

similar react-router

安装

npm install --save similar-react-router

用法

var React = reqiure('react');
var {Link,Route,Router,RouteHistory} = reqiure('simple-react-router');

var RootComponent = (props)=>{
    return (<div>
        <h2>This is RootComponent!</h2>
        <ul>
            <li>
                <Link to="/home/index" anchor={true}>首页</Link>
            </li>
            <li>
                <Link to="/home/list" anchor={true}>列表页</Link>
            </li>
            <li>
                <Link to="/home/detail/page001" anchor={true}>详情页</Link>
            </li>
            <li>
                <Link to="/other?name=Other" anchor={true}>其它页面</Link>
            </li>
        </ul>
        <div>{props.children}</div>
    </div>)
}

var HomePage = (props)=>{
	return (<div className="home-page">{props.children}</div>)
}

var OtherPage = (props)=>{
	return (<div>{"This is "+props.name+" page!"}</div>)
}


var HomeIndexPage = ()=>{
    return (<div>
        This is HomeIndexPage!
    </div>)
}

var HomeListPage = ()=>{
    return (<div>
        This is HomeListPage!
    </div>)
}

var HomeDetailPage = (props)=>{
    return (<div id={"detail-"+props.id}>
        This is HomeDetailPage!
    </div>)
}


class RouterApp extends React.Component {
	render(){
		return (
			<Router defaultRoute="/home/index" path="/" component={RootComponent}>
				<Route path="home" component={HomePage}>
					<Route path="index" component={HomeIndexPage} />
					<Route path="list" component={HomeListPage} />
					<Route path="detail/:id" component={HomeDetailPage} />
				</Route>
				<Route path="other" component={OtherPage}></Route>
			</Router>
		)
	}
}

示例项目

API

  • Router 定义根路由,指定defaultRoute(默认路由)
    • path 路由名称,这里指定为"/" String
    • component 路由对应的组件 React.Component
    • defaultRoute 默认路由 String
  • Route 定义路由,可包含子路由,允许定义[:id]格式路由,默认允许传递[?id=xxx]方式
    • path 路由名称,这里指定为"/" String
    • component 路由对应的组件 React.Component
    • children 子路由 Array<Route> or <Route>
  • Link 简单路由链接
    • to 跳转到的路由名称 String
    • onClick 路由点击回调函数,内部已经实现路由跳转 Function
    • anchor 是否渲染为a标签,否则就是span标签 Boolean
  • RouteHistory 路由操纵,注意以下是属性或者方法,非props。
    • pushHash 跳转 Function
    • curHash 当前路由 String

特点

  1. similar-react-router采用ES6写法,推荐使用webpack打包,loader采用babel-loader。

  2. require引入react方式,可以兼容IE8。

  3. 高度模仿react-router组件,采用hash实现,使用便捷。

  4. 可以在redux中使用,看这里

联系方式

Email: liuhong1happy