# nodeppt **Repository Path**: neequ_admin/nodeppt ## Basic Information - **Project Name**: nodeppt - **Description**: This is probably the best web presentation tool so far! - **Primary Language**: JavaScript - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2019-12-05 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README nodeppt - 让你爱上做分享! ============= [This is a readme file in English](./README_EN.md) [](https://nodei.co/npm/nodeppt/) [](https://nodei.co/npm/nodeppt/) **导出pdf不再支持,请使用chrome打印服务另存为pdf,url中添加`?print=1`,然后使用chrome打印 `ctrl+P` ** ## 为什么选择nodeppt **这可能是迄今为止最好的网页版演示库** * 基于GFM的markdown语法编写 * 支持[html混排](#mixed-code),再复杂的demo也可以做! * 支持多个皮肤:[colors](http://js8.in/nodeppt/?theme=colors)-[moon](http://js8.in/nodeppt/?theme=moon)-[blue](http://js8.in/nodeppt/?theme=blue)-[dark](http://js8.in/nodeppt/?theme=dark)-[green](http://js8.in/nodeppt/?theme=green)-[light](http://js8.in/nodeppt/?theme=light) * 实现watch功能`nodeppt start -w` * 支持[20种转场动画](#transition),可以设置单页动画 * 支持单页背景图片 * 多种模式:overview模式,[双屏模式](#postmessage),[socket远程控制](#socket),摇一摇换页,使用ipad/iphone控制翻页更酷哦~ * 可以使用画板,**双屏同步画板**内容!可以使用note做备注 * 支持语法高亮,自由选择[highlight样式](https://highlightjs.org/) * 可以单页ppt内部动画,单步动画 * [支持进入/退出回调](#callback),做在线demo很方便 * 支持事件update函数,查看[demo](http://js8.in/nodeppt/#12) * zoom.js:alt+click ## demo * http://js8.in/nodeppt/ * 多套皮肤:[colors](http://js8.in/nodeppt/?theme=color)-[moon](http://js8.in/nodeppt/?theme=moon)-[blue](http://js8.in/nodeppt/?theme=blue)-[dark](http://js8.in/nodeppt/?theme=dark)-[green](http://js8.in/nodeppt/?theme=green)-[light](http://js8.in/nodeppt/?theme=light) * 双屏控制:http://js8.in/nodeppt/?_multiscreen=1 记得允许弹窗哦~ * 三水清的分享:http://js8.in/slide * 打印页面:http://js8.in/nodeppt/?print=1 ## 1.4 新功能 支持单个slide事件:build/enter/leave/keypress,事件统一在`[slide]`中使用`data-on-X`来指定一个*全局函数名* ### 事件说明如下 * build:当触发下一步操作的时候,会触发这个事件,具有stop方法 * keypress:在当前页面按键触发,具有stop方法 * enter/leave:进入/离开 此页面触发的事件,无stop方法 **build/keypress会在当前slide完全渲染后触发,回调函数会接受一个event对象,如果想阻止默认事件(即翻页,或者对应的快捷键),可以使用event对象的`stop()`方法;slide退场后事件解绑** ### 使用举例 #### 示例1:进入页面如果触发翻页事件,就会当前执行做转场,做一些类似magicmove效果 ```markdown [slide data-on-build="globalCallbackName"] ``` ```javascript var count = 0; function globalCallbackName(e){ count++; if(count<2){ //做一些页面动效,或者转场 e.stop();//阻止默认事件,就不会跳转 } } ``` #### 示例2:代理空格按键事件 ```markdown [slide data-on-keypress="globalCallbackName"] ``` ```javascript function globalCallbackName(e){ if(e.keyCode==32){ //play();//触发自定义的页面效果 e.stop();//阻止默认事件,则不会触发nodeppt默认绑定的事件 } } ``` ## 文件定位 对于nodeppt内部的文件,定位需要用根目录的方式来写,例如项目路径是 `slide`,`demo.md`中的图片使用: ```markdown  ``` 对应的图片路径是 `slide/img/demo.png` 使用 `nodeppt generate demo.md output -a` 则生成后,图片路径是:`output/img/demo.png` ## magic magic是在一页幻灯片中播放多个子页面,页面之间进行动效切换,但是slide不翻页(类似keynote的magicmove),使用`[magic]`标签包裹,子页面之间使用`====`间隔 `[magic]`标签支持全部转场动效,效果比较好的有: * zoomin/zoomout * move * circle * earthquake * newspaper * cover-diamond * horizontal3d/horizontal * vertical3d * cover-circle ```markdown [slide] [magic data-transition="earthquake"] ## 标题1 -----
这是html
这是css样式
具体看下项目中 ppts/demo.md 代码
``` #### 转场回调 前端的ppt,难免会在页面中演示一些demo,除了上面的插入html语法外,还提供了```enter```和```outcallback```,分别用于:切入(切走)到当前ppt,执行的js函数名。例如: ```markdown [slide data-on-leave="outcallback" data-on-enter="incallback"] ## 当进入此页,就执行incallback函数 ## 当离开此页面,就执行outcallback函数 ``` #### 表格实例 ```markodwn ### 市面上主要的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内容~ ```markdown ``` #### 示例 类似下面的语法:(更多用法查看ppts/demo.md文件) ```markdown 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 ### 查看帮助 ```bash nodeppt -h # 任何命令都可以输入-h查看帮助 nodeppt start -h ``` ## demo演示 & 使用方法 * 执行 ```nodeppt start``` * 访问 [http://127.0.0.1:8080/](http://127.0.0.1:8080/) * 在线demo: http://js8.in/nodeppt/ ## Thanks * http://tympanus.net/Development/ItemTransitions/index2.html * http://tympanus.net/Development/PageTransitions/ * https://github.com/daneden/animate.css