zoukankan      html  css  js  c++  java
  • [React] Create and import React components with Markdown using MDXC

    In this lesson I demonstrate how to use the library MDXC to create and import React components with Markdown. MDXC converts markdown into JavaScript and supports JSX.

    Additional Resources: https://github.com/jamesknelson/mdxc

     
    Create a React app by using 'create-react-app':
    // .babelrc
    
    {
        "presets": ["babel-preset-react-app"]
    }

    Then, you can import a component from any Markdown file by prepending the filename with !babel-loader!mdx-loader!. For example:

    /* eslint-disable import/no-webpack-loader-syntax */
    import DocumentComponent from '!babel-loader!mdx-loader!../pages/index.md'

    App.js

    /* eslint-disable import/no-webpack-loader-syntax */
    
    import React, { Component } from "react";
    import logo from "./logo.svg";
    import "./App.css";
    
    import HelloWorld from "!babel-loader!mdx-loader!./HelloWorld.md";
    
    class App extends Component {
      render() {
        return (
          <div className="App">
            <header className="App-header">
              <img src={logo} className="App-logo" alt="logo" />
              <h1 className="App-title">Welcome to React</h1>
            </header>
            <p className="App-intro">
              To get started, edit <code>src/App.js</code> and save to reload.
            </p>
            <HelloWorld text="blah blah blah" />
          </div>
        );
      }
    }
    
    export default App;
    import Bold from "./Bold"
    
    import Italic from "!babel-loader!mdx-loader!./Italic.md"
    
    prop text
    
    # Heading 1
    
    ## Heading 2
    
    <p>{text}</p>
    <Bold>This text is Bold</Bold>
    <Italic>This text is Italic</Italic>

    Bold.js:

    import React from "react";
    
    export default function Bold({ children }) {
      return <b>{children}</b>;
    }

    Italic.md

    prop children
    
    {children}

    Github

  • 相关阅读:
    FileInputStream 小Demo
    GUI线程 :打字母游戏
    联合线程(案例顾客买蛋糕 :使用join()方法)
    多线程:竞赛
    线程:交通灯
    猜数字游戏
    正则表达式
    音频播放的三种方式:
    进阶篇-用户界面:7.android动画-自定义视图动画
    进阶篇-用户界面:6.android studio使用github开源库实现下拉刷新
  • 原文地址:https://www.cnblogs.com/Answer1215/p/9828093.html
Copyright © 2011-2022 走看看