IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    推荐nodeppt:使用markdown语法来写网页ppt

    三水清 (ksky521@gmail.com)发表于 2014-07-20 04:15:06
    love 0

    nodePPT 是@三水清基于nodejs来写的网页PPT,之前的版本仅仅是html语法,现在可以支持通过markdown来写网页ppt了。

    nodeppt Demo

    查看demo:http://qdemo.sinaapp.com/

    安装

    nodeppt

    1
    
    npm install -g nodeppt
    

    使用nodeppt命令行

    启动

    1
    2
    3
    
    nodeppt start -p port
    # or
    nodeppt start -p port -d path/for/ppts
    

    创建

    支持markdown语法快速创建网页幻灯片。

    1
    
    nodeppt create ppt-name
    



    按照提示输入基本信息后就可以创建,默认创建是markdown版本,如果需要创建html版本,可以使用:

    1
    2
    3
    
    nodeppt create ppt-name.html
    # or
    nodeppt create ppt-name.htm
    

    nodeppt markdown语法

    说明
    nodeppt是支持marked语法的,但是为了制作出来更加完美的ppt,扩展了下面的语法

    配置

    基本配置如下:

    1
    2
    3
    4
    5
    
    title: 这是演讲的题目
    speaker: 演讲者名字
    url: 可以设置链接
    transition: 转场效果,例如:zoomin
    files: 引入js和css的地址,如果有的话~自动放在页面底部
    

    目录关系:可以在md同级目录下创建img、js、css等文件夹,然后在markdown里面引用,nodeppt默认会先查找md文件同级目录下面的静态资源,没有再找默认的 assets 文件夹下静态内容

    支持的18种转场动画包括:

    horizontal3d horizontal
    vertical3d zoomin
    zoomout cards
    。。。

    如果设置单页动画,请参考下面的
    *单页动画设置部分~

    ### 分页
    通过[slide]作为每页ppt的间隔,如果需要添加单页背景,使用下面的语法:

    1
    2
    3
    
    [slide style="background-image:url('/img/bg1.png')"]
    # 这是个有背景的家伙
    ## 我是副标题
    

    单页ppt上下布局

    1
    2
    3
    4
    5
    6
    7
    
    [slide]
    ## 主页面样式
    ### ----是上下分界线
    ----
    nodeppt是基于nodejs写的支持 **Markdown!** 语法的网页PPT
    
    nodeppt:https://github.com/ksky521/nodePPT
    

    代码格式化

    语法跟Github Flavored Markdown 一样~

    单页动画设置

    在md文件,顶部 配置 可以设置全局转场动画,如果要设置单页的转场动画,可以通过下面的语法

    1
    2
    
    [slide data-transition="vertical3d"]
    ## 这是一个vertical3d的动画
    

    插入html代码

    如果需要完全diy自己的ppt内容,可以markdown和html混编代码。例如:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    
    ## 混编html和markdown
    ----
    
    <div class="file-setting">
        <p>这是htmlp>
    div>
    <p id="css-demo">这是css样式p>
    <p>使用[code][/code]包裹的代码,会直接插入到页面p>
    <p>具体看下项目中 ppts/demo.md 代码p>
    <script>
        function testScriptTag(){
    
        }
        console.log(typeof testScriptTag);
    script>
    <style>
    #css-demo{
        color: red;
    }
    style>
    

    出入回调

    前端的ppt,难免会在页面中演示一些demo,除了上面的插入html语法:[code][/code] 之外,还提供了in-callback和out-callback,分别用于:切换(切走)到当前ppt,执行的js函数名。例如:

    1
    2
    3
    
    [slide data-outcallback="outcallback" data-incallback="incallback"]
    ## 当进入此页,就执行incallback函数
    ## 当离开此页面,就执行outcallback函数
    

    表格实例

    1
    2
    3
    4
    5
    6
    7
    8
    
    ### 市面上主要的css预处理器:less\sass\stylus
    ---
     |less| sass | stylus
    :-------|:------:|-------:|--------
    环境 |js/nodejs | Ruby | nodejs
    扩展名 | .less | .sass/.scss | .styl
    特点 | 老牌,用户多,支持js解析 | 功能全,有成型框架,发展快 | 语法多样,小众
    案例/框架 | [Bootstrap](http://getbootstrap.com/) | [compass](http://compass-style.org) [bourbon](http://bourbon.io) |
    

    插入iframe

    使用data-src作为iframe的url,这样只有切换到当前页才会加载url内容~

    1
    
    <iframe data-src="http://www.google.com/doodle4google/resources/history.html" src="about:blank;">iframe>
    

    导出ppt

    这么高端大气上档次的ppt,怎么能不导出分享给大家呢??

    导出ppt有两种,一种是pdf版,一种是html版

    pdf版

    需要安装phantomJS。

    1
    2
    3
    4
    5
    6
    
    # 安装phantomjs,如果安装了,请忽略
    npm install -g phantomjs
    # 启动nodeppt server
    nodeppt start
    # 导出文件
    nodeppt pdf http://127.0.0.1:8080/md/demo.md -o a.pdf
    

    ### html版

    1
    2
    3
    4
    5
    6
    7
    
    # 使用generate命令
    nodeppt generate filepath
    # 导出全部,包括nodeppt的js、img和css文件夹
    # 默认导出在publish文件夹
    nodeppt generate ./ppts/demo.md -a
    # 指定导出文件夹
    nodeppt generate ./ppts/demo.md -a -o output/path
    

    导出目录下所有ppt,并且生成ppt list首页:

    1
    
    nodeppt path -o output/path -a
    

    示例

    类似下面的语法:(更多用法查看ppts/demo.md文件)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    
    title: nodeppt markdown 演示
    speaker: Theo Wang
    url: https://github.com/ksky521/nodePPT
    transition: zoomin
    
    [slide]
    
    # 封面样式
    ## h1是作为封面用的,内部的都用h2
    
    [slide style="background-image:url('/img/bg1.png')"]
    
    # 背景图片 {:&.flexbox.vleft}
    ## 使用方法:[slide style="background-image:url('/img/bg1.png')"]
    
    [slide]
    
    ## 主页面样式
    ### ----是上下分界线
    ----
    
    nodeppt是基于nodejs写的支持 **Markdown!** 语法的网页PPT
    
    nodeppt:https://github.com/ksky521/nodePPT
    
    [slide]
    
    什么?这些功能还不够用?
    
    极客模式:查看源码的nodeppt.js,相信你会找到牛逼的手机互动(摇一摇换页)功能
    
    查看项目目录ppts获取更多帮助信息
    

    更多demo,查看 ppts 目录的demo

    查看帮助

    1
    
    nodeppt -h
    

    demo演示 & 使用方法

    • 执行 nodeppt start
    • 访问 http://127.0.0.1:8080/
    • 查看在线demo:http://qdemo.sinaapp.com/


沪ICP备19023445号-2号
友情链接