V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
xjh22222228
V2EX  ›  分享创造

这应该是目前第三方 CNode 功能最全面最像的一个吧

  •  
  •   xjh22222228 · 2018-02-27 11:55:41 +08:00 · 1964 次点击
    这是一个创建于 2493 天前的主题,其中的信息可能已经有所发展或是发生改变。

    基于 React 实现的一个有点相似 CNode 社区网站

    这应该是目前第三方 CNode 功能最全面最像的一个吧,如果不是麻烦贴上地址打我脸。

    献给刚入门或还在学 React 的同学们, 有你们社区才会更强大!

    2018-02-27

    源码 github

    在线预览

    技术栈

    "react": "^16.2.0",
    "react-dom": "^16.2.0",
    "react-router-dom": "^4.2.2",
    "mobx": "^3.4.1",
    "mobx-react": "^4.3.5",
    "antd": "^3.1.6",
    "axios": "^0.17.1",
    "moment": "^2.20.1",
    "webpack": "3.8.1",
    "simplemde": "^1.11.2",
    "scss": "",
    "ES6": "",
    "flex": "",
    

    开发目录

    .
    ├── LICENSE
    ├── README.md
    ├── config
    │   ├── env.js
    │   ├── jest
    │   │   ├── cssTransform.js
    │   │   └── fileTransform.js
    │   ├── paths.js
    │   ├── polyfills.js
    │   ├── webpack.config.dev.js
    │   ├── webpack.config.prod.js
    │   └── webpackDevServer.config.js
    ├── package-lock.json
    ├── package.json
    ├── public                       # 静态资源目录
    │   ├── images
    │   │   ├── 11.png
    │   │   ├── 22.png
    │   │   ├── 33.png
    │   │   └── 44.png
    │   ├── index.html
    │   └── manifest.json
    ├── scripts
    │   ├── build.js
    │   ├── start.js
    │   └── test.js
    └── src                          # 开发目录,源码文件
        ├── App.jsx                  # views 入口文件
        ├── api                      # API 配置
        │   └── index.js
        ├── assets                   # 资源目录,跟 public 不同的是 assets 会被 webpack 处理
        │   ├── images
        │   │   ├── app-qrcode.png
        │   │   ├── github.svg
        │   │   └── not-match.gif
        │   └── scss
        │       ├── _variable.scss
        │       ├── media.scss
        │       └── style.scss
        ├── components               # 组件目录
        │   ├── footer               # 底部组件
        │   │   ├── Footer.jsx
        │   │   └── footer.scss
        │   ├── header               # 头部组件
        │   │   ├── Header.jsx
        │   │   └── header.scss
        │   ├── sidebar              # 侧边栏组件
        │   │   ├── Sidebar.jsx
        │   │   └── sidebar.scss
        │   └── topics-list          # 话题列表组件
        │       ├── TopicsList.jsx
        │       └── topicsList.scss
        ├── index.js                 # 程序主入口
        ├── registerServiceWorker.js # 这个文件的作用是缓存,下次打开会更快
        ├── router                   # 路由配置
        │   └── index.jsx
        ├── store                    # 状态管理
        │   └── index.jsx
        ├── utils                    # 封装的一些公用方法
        │   └── index.js
        └── views                    # 视图目录
            ├── 404                  # 404 页
            │   ├── 404.jsx
            │   └── 404.scss
            ├── collections          # 用户话题收藏页
            │   ├── Collections.jsx
            │   └── collections.scss
            ├── index                # 首页
            │   ├── Index.jsx
            │   └── style.scss
            ├── login                # 登录页
            │   ├── Login.jsx
            │   └── login.scss
            ├── messages             # 未读消息
            │   ├── Messages.jsx
            │   └── messages.scss
            ├── release              # 发布 /编辑话题
            │   ├── Release.jsx
            │   └── release.scss
            ├── topic                # 主题详情页
            │   ├── Topic.jsx
            │   └── topic.scss
            └── user                # 用户详情页 /个人主页
                ├── User.jsx
                └── user.scss
    

    API 清单 x 15

    • [√] 主题首页
    • [√] 主题详情
    • [√] 新建主题
    • [√] 编辑主题
    • [√] 收藏主题
    • [√] 取消收藏主题
    • [√] 用户所收藏的主题
    • [√] 新建评论
    • [√] 为评论点赞
    • [√] 用户详情 /个人主页
    • [√] 登录
    • [√] 获取未读消息数
    • [√] 获取已读和未读消息
    • [√] 标记全部已读
    • [√] 标记单个消息为已读

    启动程序

    # install dependencies
    npm install
    
    # serve with hot reload at localhost:3888
    npm start
    
    # build for production with minification
    npm run build
    
    

    结语

    • CNode 主题详情是使用 markdown 写的,样式可以使用 github-markdown-css。
    • CNode 提供的 API 获取主题没有返回总条数导致不能算出总页数, 所以我写死了 250 页。
    • 大部分功能都需要登录的,所以游客只能进行浏览,如果感兴趣的可以尝试登录, 不会保存你的 accesstoken, 欢迎监督。
    • 发布话题和评论使用的 markdown 编辑器 simplemde
    • 因为托管在 github 上,所以首次打开的速度会稍微慢一点,之后基本上是秒开。
    • 如果没漏的话提供的 API 功能都已经全部开发完成了,如有漏麻烦反馈下哈,感谢!

    ...

    👍👍👍


    License

    MIT

    1 条回复    2018-02-27 12:37:48 +08:00
    xjh22222228
        1
    xjh22222228  
    OP
       2018-02-27 12:37:48 +08:00
    占个楼
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1182 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 18:16 · PVG 02:16 · LAX 10:16 · JFK 13:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.