居然可以用 js 写 PPT 用powerpoint或者keynote写演示文稿,对于代码、数学公式等的支持一直是个痛点。而且对于前端同学来说,一身的css功力用不上也是个痛点。...在我们上面默认的html模板中已经加载了RevealMarkdown插件。所以我们要做的就是在下面的模板上写markdown就好。...: 代码高亮 代码高亮默认是支持的,我们可以在markdown里面用```来使用: 显示出来的效果如下: md-code 也可以直接使用html的pre和code标签来显示: ...而且也可以跟reveal.js的功能有更好的结合。...更进一步 除了上面介绍的基本特性之外,reveal.js支持自动播放、自制插件、支持处理事件等等有利于开发人员写slides的特性。相信能给你的slides带来新的好玩的东西,将汇报与分享变成乐趣。
ES6 提供的许多新特性。...用这些新特性,我们能在不降低代码可读性与维护性的基础上畅快地写 JavaScript~ 箭头函数 将数组的内容 * 2 以前我们这么写 [1, 2, 3].map(function(each){...return each * 2; }); 用 ES6 只需这样写 [1, 2, 3].map(each=> each * 2); // 或 [1, 2, 3].map((each)=> each * 2...){ name = name || 'Jack'; } 用 ES6 只需这样写 var introSomeBody = (name = 'Jack') => { } 不定参数 数字求和 以前我们这么写...; }, 0); } 解构(Destructuring)赋值 交换两个变量的值 以前我们这么写 var temp = a; a = b; b = a; 用 ES6 只需这样写 [a, b] =
前言 在这篇文章中,我们将通过 JS 构建我们自己的 JS 解释器,用 JS 写 JS,这听起来很奇怪,尽管如此,这样做我们将更熟悉 JS,也可以学习 JS 引擎是如何工作的!...一个完全使用 javascript 实现的,小型且快速的 javascript 解析器 本次实践我们将使用 acorn.js ,它会帮我们进行词法分析,语法解析并转换为抽象语法树。...Webpack/Rollup/Babel(@babel/parser) 等第三方库也是使用 acorn.js 作为自己 Parser 的基础库。(站在巨人的肩膀上啊!)...acorn.js parse 返回值符合 ESTree spec 描述的 AST 对象,这里我们使用@types/estree 做类型定义。...: Expression | null; } Identifier 顾名思义,标识符节点,我们写 JS 时定义的变量名,函数名,属性名,都归为标识符。
用原生js写一个"多动症"的简历 预览地址 源码地址 最近在知乎上看到@方应杭用vue写了一个会动的简历,觉得挺好玩的,研究一下其实现思路,决定试试用原生js来实现。...使用es6的写法 使用部分原生dom操作api standard.js(代码风格约束利器) 目录结构如下 最重要的几个模块分别是resumeEditor(简历编辑模块) 、 stylesEditor(...简历样式编辑模块) 、 以及vQuery(封装的dom操作模块) 最后app.js(入口模块)再将几个模块的功能结合起来完成整个项目。...,你没看错,传说中的回调地狱,亮瞎了我的狗眼啊。想必大家和我一样都是不愿意看到这坨恶心的代码的,但对于处理异步问题,回调又的确是一直以来的解决方案之一。...markdownToHtmlWrap) .then(showStylesWrap.bind(null, 2)) 可以看到,代码清爽了很多,纵向发展,应用第一步第二步第三步...一眼就能够看出来,当然实现的逻辑是将原来的相关的模块用
大家好,又见面了,我是你们的朋友全栈君。 如图,最简单的纯粹的选项卡 第一步,当然是先写html代码和css样式 的时候,再循环让所有选项卡的act样式去掉,所有的内容隐藏。然后让所点击的选项及对应内容显示。...上面的写法只能一个页面用一个选项卡,如果再加一个的话,就需要复制一份,再改很多变量名。...要点:tab_t_li[i][evt] 因为传值的时候是字符串,如果直接写的话就是tab_t_li[i].”onclick”这样话是执行不了的,tab_t_li[“onclick”]这样执行没问题。...,可以看下一篇 用js写简单选项卡 加 自动切换效果 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/155183.html原文链接:https://javaforall.cn
用原生js写一个"多动症"的简历 预览地址 源码地址 最近在知乎上看到@方应杭用vue写了一个会动的简历,觉得挺好玩的,研究一下其实现思路,决定试试用原生js来实现。...使用es6的写法 使用部分原生dom操作api standard.js(代码风格约束利器) 最重要的几个模块分别是resumeEditor(简历编辑模块) 、 stylesEditor(简历样式编辑模块...) 、 以及vQuery(封装的dom操作模块) 最后app.js(入口模块)再将几个模块的功能结合起来完成整个项目。...,你没看错,传说中的回调地狱,亮瞎了我的狗眼啊。想必大家和我一样都是不愿意看到这坨恶心的代码的,但对于处理异步问题,回调又的确是一直以来的解决方案之一。...markdownToHtmlWrap) .then(showStylesWrap.bind(null, 2)) 可以看到,代码清爽了很多,纵向发展,应用第一步第二步第三步...一眼就能够看出来,当然实现的逻辑是将原来的相关的模块用
模板引擎在前后端都能用到,但是通过作为前端,我们只需要一些简单的模板引擎。 先上代码: { user.company } js...{ return fn.apply(model); }; } 这个我们能用这个模板引擎创建一个我们前端需要的html...这里面我们使用正则表达式去匹配字符串中的变量,当然,你要对js正则表达式熟练应用。
2、使用yarn来处理依赖包的管理 3、使用es6的写法 4、使用部分原生dom操作api 5、standard.js(代码风格约束利器) 目录结构如下 最重要的几个模块分别是resumeEditor...(简历编辑模块) 、 stylesEditor(简历样式编辑模块) 、 以及vQuery(封装的dom操作模块) 最后app.js(入口模块)再将几个模块的功能结合起来完成整个项目。...想必大家和我一样都是不愿意看到这坨恶心的代码的,但对于处理异步问题,回调又的确是一直以来的解决方案之一。...因为定时器的操作是异步行为,而我们的简历生成过程会涉及到多个异步操作,所以为了看到如首页预览链接的效果,必须等前一个步骤完成之后,才能执行下一步步骤,这里首先使用的回调函数的解决方案,大家可以从github...我们来看一下promise分支中app模块最终的写法 可以看到,代码清爽了很多,纵向发展,应用第一步第二步第三步...一眼就能够看出来,当然实现的逻辑是将原来的相关的模块用Promise包装起来,并且在原来回调函数执行的地方
公司有非常多手机app的项目。手机app又要常常訪问后台提交与查询数据。 所曾经端app与后台的开发与測试过程中接口调试是一个常常要做的工作。...而非本项目的人往往还难以帮上忙(必需要读懂别人写的程序,等等的。...开发们都懂的…) 所以自己利用了业余时间用js+hta的方式实现了一个简单的接口调试程序.能够由非开发者对比接口文档就能够进行接口的调试和測试。...下面是程序界面 这是一个机票程序的的接口调用程序,在这个程序中能够调试全部的接口 左側是各个接口的命名,每点击左側的接口名,右側的url和req(请求參数)会对应变为该接口的URL和參数样例,点以下的...程序小巧(10-100k) 该程序入门简单(仅仅须要懂一点html语法与js就可以), 改动easy(用记录本打开就能改动), 执行easy(windows环境下双击执行就可以) 实在是居家旅行,出差工作
解决apache+python无法执行一些root命令的问题 用root启动python服务器端,远程可以执行任何root命令 #/usr/bin/python #Filename:agent.py
;我为了方便都写到一个html中了;请把这个script标签中的内容单独写在一个js文件里 //整个插件写在一个立即执行函数里;就是function(){}();函数自执行;保证里面的变量不会与外界互相影响...; //最后面的undefined可不写;最好写了;保证里面再出现的undefined是未定义的意思;不被其他东西赋值; //好了下面是时候展现真正的技术了 //function前的!...号(叹号)或者;(分号)这不是写错了,为了防止那个二货写的js结束没有分号;而可能发生报错 /* ;function(win,doc,$,undefined){ }(window...this的指向为调用的实例;我们此时姑且认为this就指向这个函数;因为这样我们之后再想获取这个div就可以直接用this.div了好吗;而不是在document.getElementById(。。。。...指向点击的button;只要在写var _self = this;就可以用_self 代替this(函数实例)了;当然_self 也可以写成别的 比如$this等自定义的 }*/
排除了AI的加成,发现这个功能其实也可以通过数学理论和简单代码来实现。经过一番折腾,终于用JS实现了大致的功能,然后我把它名为 smart-predictor。...在明白这些结论之后,我们就可以去讨论它到底是怎么实现的。 Separator 我们用数组 [1,2,'a1c','a2c']作为例子。...'Number1': [{ realValue: '6', ... }, { realValue: '8', ... }] } 代码请戳:classifier.js...代码请戳:linearRegression.js 通过这条公式,我们可以轻易得到数组 [1,3]的斜率和偏移量为 {a:2,b:1},然后就可以知道以后的数据走向将会是 [5,7,9,...]。...10', index: 10, ... }, { realValue: '12', index: 11 ... }] } 代码请戳:predictor.js
jenkins.xxx.cn'; const basicUrl = `http://${token.user}:${token.password}@${host}`; BUILD 调用 jenkins 提供的...jenkins.job.get() 获取当前 job 的信息。...data.lastBuild.number 可以拿到最后一个 build 的 number,最后一个 build 也就是我们刚刚触发的 build。...jenkins.build.get() 获取当前 build 的信息。...data.result 获取当前 build 的结果 jenkins.job.get(job_name, (err, data) => { if (err) throw err; const
这种带有js的网站抓取其实不是那么简单的,基本分为那么几种方法,一种是观察页面,有的会有json数据,有的有js代码可以解析目标的url;一种是使用渲染工具;还有一种就是用工具来点击相关button,来抓取...今天我们使用的是第三种。 ? 我们希望爬取的是表格中的数据,但是如果我们仔细看一下html代码,会发现,这其实是js生成的,下面这张图是源代码的截图。 ? ...我们自己自己解析url数据访问你的api好了。 我们用浏览器自带的解析功能来试一下。首先,我们打开network,chrome内核的好像都这么叫。 ? ...然后我们就点击第二页、第三页不断的来观察究竟js代码访问了什么后台的url。...接下来我们就可以用urllib来获得api背后的json内容了,比如是这样的: ?
不过从这个例子里也能小小练习一下Promise的用法。 这里要乘100的原因是防止几毫秒差别太小被抢占。...同时,得益于Promise,我们在异步函数里可以这样写: (async () => { const data = await sleepSort([4, 5, 3, 6, 8]) console.log...(data) // [ 3, 4, 5, 6, 8 ] })() 真的是非常的实用,非常的高效啊(赞)。
马上春节了,回家的不回家的,有钱的没钱的,对家人、爱人、以及情人的礼物别忘了。 做一点有意思的事,送爱人一束玫瑰花吧!...注意哦,是带渐变效果的 动态渐变--> 操作方法: 1.新建个txt文件,将下面的源码复制到文件中 2.将txt文件的后缀名修改为html,无法查看后缀名的(我的电脑,查看,勾选文件扩展名复选框...) 3.双击打开html文件 4(以下是需要复制的源码) var b = document.body; var c =
选自一本用Python编写自己的电脑游戏一书 import random HANGMANPICS = [''''' +---+ | | |...blanks = '_' *len(secretWord) #将所选单词所有字母替换成"_" for i in range(len(secretWord)): ########这段程序的难点...else: return guess #返回用户输入的字母 def playAgain(): #判断是否继续游戏 print() return input...(yea or no):').lower().startswith('y') # lower(): #输入的字符串转变成小写; print(' == H A N G M A N =...True: displayBoard(HANGMANPICS,missedLetters,correctLetters,secretWord) # 调用displayBoard函数,并传递相应的值
在这样的时代背景下,对于每一个基于代码的自动化测试而言,最痛苦的事莫过于接手了一段辣眼睛的代码。BUG不BUG是其次,更多的时候是看到了一段拥有无数嵌套、晦涩难懂、宛如天书的代码。...原先就一知半解,遇到这样的代码更是难上加难。今天我们就来看看,应该拿什么来拯救那些稀烂的代码。 1、把注释和代码混在一起的代码: 高亮显示后: 如果只做边界的测试,那么就悲剧了。...VSCode,然后【Shift】+【Alt】+F,真香 9、鬼才逻辑: *** 10、充分训练客户自己的排查能力,别一有什么问题就找我们乙方 一般我都直接写百度的。。...话说回来,编写一段雅观的代码,往往需要相当深厚的功力。优秀的代码不仅要有一个中心思想让人一眼辨认,还要在精炼与易读之间做权衡。...Linux之父Linus Torvalds说:如果你的代码里需要有超过三层的缩进,那么你已经搞砸了,应该修改你的代码。
前言 最近在使用码云的giteepages功能在码云上放了几个网页,在实现基本的展现之后,此时博主在想怎么可以再不调用后端接口的方式进行安全验证呢,为了将白嫖进行到底,还真有一个小方法,一起来看看吧。...解决思路 其实整体思路很简单,灵感是来自于当时使用jwt做安全验证的一个小demo,主要就是要利用一个浏览器附带的一个本地存储器—localStorage,这个东西主要起的功能就是在我们验证密码正确之后...,将登陆成功的信息存储在本地,方便我们在访问其他页面时可以通过验证localStorage中存储的信息进行验证是否登录,整体思路就是这样,来看看怎么解决吧。...-- Scripts --> js/jquery.min.js"> js/us.js">.../jquery.min.js"> js/us.js"> $(function
如果你不会Python语言,正好又是一个node.js小白,看完这篇文章之后,一定会觉得受益匪浅,感受到自己又新get到了一门技能,如何用node.js从零开始去写一个简单的爬虫,十分钟时间就能搞定,步骤其实很简单...node的安装就不一步步的解释了,如果不会可以自行百度。在node开大环境下开始第一步: 1:在d盘新建一个文件夹WebSpider ?...图片.png 创建FirstSpider文件夹之后的目录 ? 图片.png 4:进入刚刚创建的文件夹里面 cd FirstSpider ?...图片.png 7:重点内容,打开first_spider,并一行一行的敲代码,如果你不想写代码的话,去网站上找一些代码过来进行测试即可。...}) } } }) } 8:运行程序,命令很简单哦 在cmd命令行下,cd 到你创建工程文件夹FirstSpider下,然后 node first_spider.js
领取专属 10元无门槛券
手把手带您无忧上云