nodePPT 是@三水清基于nodejs来写的网页PPT,之前的版本仅仅是html语法,现在可以支持通过markdown来写网页ppt了。
查看demo:http://qdemo.sinaapp.com/
nodeppt
1 | npm install -g nodeppt |
1 2 3 | nodeppt start -p port # or nodeppt start -p port -d path/for/ppts |
支持markdown语法快速创建网页幻灯片。
1 | nodeppt create ppt-name |
1 2 3 | nodeppt create ppt-name.html
# or
nodeppt create ppt-name.htm
|
说明
nodeppt是支持marked语法的,但是为了制作出来更加完美的ppt,扩展了下面的语法
基本配置如下:
1 2 3 4 5 | title: 这是演讲的题目 speaker: 演讲者名字 url: 可以设置链接 transition: 转场效果,例如:zoomin files: 引入js和css的地址,如果有的话~自动放在页面底部 |
assets
文件夹下静态内容[slide]
作为每页ppt的间隔,如果需要添加单页背景,使用下面的语法:1 2 3 | [slide style="background-image:url('/img/bg1.png')"] # 这是个有背景的家伙 ## 我是副标题 |
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的动画 |
如果需要完全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) | |
使用data-src
作为iframe的url,这样只有切换到当前页才会加载url内容~
1 | <iframe data-src="http://www.google.com/doodle4google/resources/history.html" src="about:blank;">iframe> |
这么高端大气上档次的ppt,怎么能不导出分享给大家呢??
导出ppt有两种,一种是pdf版,一种是html版
需要安装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 |
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 |
nodeppt start