为什么选择nodePPT
- 基于GFM的markdown语法编写
- 支持html混排,再复杂的demo也可以做!
- 导出网页或者pdf更容易分享
- 支持20种转场动画,可以设置单页动画
- 支持单页背景图片
- 多种模式:overview模式,双屏模式,socket远程控制,摇一摇换页,使用ipad/iphone控制翻页更酷哦~
- 可以使用画板,双屏同步画板内容!可以使用note做备注
- 支持语法高亮,自由选择highlight样式
- 可以单页ppt内部动画,单步动画
- 支持进入/退出回调,做在线demo很方便
- 支持事件update函数,查看demo
0.9.0新功能
- 添加画板多端同步
- 添加按钮控制进度
- 新增两种转场动效,增加事件绑定方法:
Slide.on
- 修复一些bug
demo
- http://qdemo.sinaapp.com/
- 双屏控制:http://qdemo.sinaapp.com/?_multiscreen=1 记得允许弹窗哦~
- 手机百度前端之路:http://qdemo.sinaapp.com/box-fe-road.htm
theme 自定义
感觉默认的模板不符合新意?可以支持自定义模板,查看theme.moon
自定义后的模板路径在markdown的设置里填写:
1 | title: 这是演讲的题目 |
安装
1 | npm install -g nodeppt |
shell使用
启动
1 | # 获取帮助 |
1 | nodeppt start -p 8090 -d path/for/ppts |
启用socket控制
方法一:使用start
命令行
1 | nodeppt start -c socket |
在页面按键【Q】显示控制url的二维码和控制链接(需要隐身窗口打开),手机上可以使用左右touch滑动和摇一摇切换下一页
方法二:使用url参数
1 | http://127.0.0.1:8080/md/demo.md?controller=socket |
在页面按键【Q】显示控制url的二维码和控制链接(需要隐身窗口打开),手机上可以使用左右touch滑动和摇一摇切换下一页
启用postMessage控制
默认使用postMessage多窗口控制,打开方法:
1 | http://127.0.0.1:8080/md/demo.md?_multiscreen=1 |
事件绑定
使用函数Slide.on
,目前支持update函数,即转场后的回调。示例代码:
1 | Slide.on('update', function(i, itemIndex, cls) { |
demo中第13张使用回调做了魔幻翻页效果
导出ppt
这么高端大气上档次的ppt,怎么能不导出分享给大家呢??
导出ppt有三种,一种最简单直接ctrl+P,一种是pdf版,一种是html版
pdf版
需要安装phantomJS。
1 | # 安装phantomjs,如果安装了,请忽略 |
html版
1 | # 获取generate帮助 |
导出目录下所有ppt,并且生成ppt list首页:
1 | nodeppt path -o output/path -a |
1 |
|
目录关系:可以在md同级目录下创建img、js、css等文件夹,然后在markdown里面引用,nodeppt默认会先查找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
33
34
35
<a name="transition"></a>
支持的转场动画包括:
* kontext
* vkontext
* circle
* cover-circle
* cover-diamond
* earthquake
* cards
* glue
* stick
* move
* newspaper
* slide
* slide2
* slide3
* horizontal3d
* horizontal
* vertical3d
* zoomin
* zoomout
* pulse
如果设置单页动画,请参考下面的**[单页动画设置](#transition-page)**部分~
#### 分页
通过```[slide]```作为每页ppt的间隔,如果需要添加单页背景,使用下面的语法:
```markdown
[slide style="background-image:url('/img/bg1.png')"]
# 这是个有背景的家伙
## 我是副标题
单页ppt上下布局
1 | [slide] |
代码格式化
语法跟Github Flavored Markdown 一样~
单页动画设置
在md文件,顶部 1
2
3
4
```markdown
[slide data-transition="vertical3d"]
## 这是一个vertical3d的动画
插入html代码
如果需要完全diy自己的ppt内容,可以直接使用 html标签,支持markdown和html混编。例如:
1 | <div class="file-setting"> |
转场回调
前端的ppt,难免会在页面中演示一些demo,除了上面的插入html语法外,还提供了1
2
3
4
5
```markdown
[slide data-outcallback="outcallback" data-incallback="incallback"]
## 当进入此页,就执行incallback函数
## 当离开此页面,就执行outcallback函数
表格实例
1 | ### 市面上主要的css预处理器:less\sass\stylus |
插入iframe
使用1
2```markdown
<iframe data-src="http://www.baidu.com" src="about:blank;"></iframe>
示例
类似下面的语法:(更多用法查看ppts/demo.md文件)
1 | title: nodeppt markdown 演示 |
更多demo,查看 1
2
3
4
5
6
7
### 查看帮助
```bash
nodeppt -h
# 任何命令都可以输入-h查看帮助
nodeppt start -h
demo演示 & 使用方法
- 执行
nodeppt start
- 访问 http://127.0.0.1:8080/
- 在线demo: http://qdemo.sinaapp.com/