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

kebisheng

v0.0.1

Published

使用 React 将 markdown 文件生成 SPA 页面

Downloads

3

Readme

毕昇

Build status npm package NPM downloads Dependency Status

中文 | English

毕胜是中国历史上第一个的可移动式技术的发明家。

bisheng 旨在使用 ReactMarkdown(以及其他带有转换器的静态文件)转换为静态网站和博客。

用 BiSheng 建立的网站

您可以使用依赖 BiSheng 建立的出色网站创建PR,以扩展此列表。

特性

bisheng 基于 dora & webpack & React & react-router, 它具有以下功能:

大图

Big picture of BiSheng

文章

使用方法

安装:

npm install --save-dev bisheng

npm scripts 中添加 start 命令

{
  "scripts": {
    "start": "bisheng start"
  }
}

创建 bisheng.config.js, 否则 bisheng 将会使用默认配置:

module.exports = {
  source: './posts',
  output: './_site',
  theme: './_theme',
  port: 8000,
};

小帖士: 请确保 sourcetheme 文件夹存在,并且 theme 文件夹不应该为空。如果你不知道如何开发一个主题,直接使用 bisheng-theme-one 就可以了。这里 是一个简单的 Demo。

现在直接运行 npm start 就可以了。

文档

CLI

我们可以全局安装 bisheng 作为一个终端命令,通过 bisheng -h 获取帮助。但是,我们还是更建议你将 bisheng 作为 devDependencies 进行安装。

$ npm install -g bisheng
$ bisheng -h
  Usage: bisheng [command] [options]

  Commands:

    start [options]     to start a server
    build [options]     to build and write static files to `config.output`
    gh-pages [options]  to deploy website to gh-pages
    help [cmd]          display help for [cmd]

  Options:

    -h, --help     output usage information
    -V, --version  output the version number

配置

bisheng 将会读取 bisheng.config.js 作为它的配置文件,但是我们可以通过 --cinfig 命令来设置配置文件的名字,就像这样:bisheng --config another.config.js

bisheng.config.js 的内容就像这样。

module.exports = {
  port: 8000,
  source: './posts',
  output: './_site',
  theme: './_theme',
  htmlTemplate: path.join(__dirname, '../template.html'),
  devServerConfig: {},
  webpackConfig(config) {
    return config;
  },
  hash: false,

  entryName: 'index',
  root: '/',
};

port: Number

default: 8000

设置启动本地服务的端口号。

source: String | Array[String] | Object{ [category]: String | Array[String]}

default: './posts'

设置 MarkDown 文件的位置。

并且 source 中所有的 MarkDown 文件都会被解析成结构化数据,例如:

posts
└── dir1
  ├── a.md
  └── b.md

将会输出一个 MarkDown 数据树。

{
  dir1: {
    a: {...},
    b: {...},
  },
}

并且每一个 MarkDown 文件都会被解析成 MarkDown 数据。实际上,MarkDown 数据是 mark-twain 的返回值,然后他会被插件处理。

exclude: RegExp

default: null

如果你想在 source 文件夹中排除一些文件,直接使用 exclude,然后毕昇就会不解析符合 exclude 的文件。

output: String

default: './_site'

设置 bisheng 生成文件 (HTML & CSS & JavaScript) 的位置。

theme: String

default: './_theme'

设置主题目录,他也可以是一个 npm 包的名称。

More about theme.

themeConfig: any

undefined

你的主题提供的一组配置项,并且你的主题会从 props.themeConfig 中读取配置。

小贴士: themeConfig 将在传递到 props 之前被 JSON.stringify, 所以你不能通过themeConfig传递函数或者正则表达式。

htmlTemplate: String

default: bisheng/lib/template.html

毕昇根据这个 HTML 模板去生成界面。

小贴士: 模板将会被 nunjucks 解析, 并且你可以在模板中使用下面的变量:

htmlTemplateExtraData: Object

default: {}

生成 htmlTemplate 的额外数据。

devServerConfig: Object

default: {}

你可以查阅 webpack-dev-server's documentation

postcssConfig: Object

default: {
    plugins: [
      rucksack(),
      autoprefixer({
        browsers: ['last 2 versions', 'Firefox ESR', '> 1%', 'ie >= 8', 'iOS >= 8', 'Android >= 4'],
      }),
    ],
  }

你可以查阅 webpack postcss-loader's documentation

webpackConfig: (config) => config

default: (config) => config

为了修改 webpack 配置, 你可以像 这样 拓展配置。

transformers: Object[]

[{ test: /.md$/, use: MarkdownTransformer }]

用于转换静态文件的转换器列表。

entryName: String

default: 'index'

webpack将生成的文件的名称,比如 [entryName].js & [entryName].css.

root: String

default: '/'

如果网站将部署在一个域的子目录下 (就像 http://benjycui.github.io/bisheng-theme-one/),我们必须设置它 (例如 /bisheng-theme-one/).

License

MIT