草庐IT

CPU设计实现

全部标签

javascript - 设计在 DOM 中表示 UI 对象的 JavaScript 类的最佳实践是什么?

我非常熟悉JavaScript和OOP,但对设计用于UI(HTML)编程的JS类非常不熟悉。我四处搜索了一下,但没有发现任何普遍的模式。假设我想动态创建类似面板的对象(类似于MicrosoftWindows面板)。每个对象都需要一个容器、一个可以包含文本标签的标题区域和一个具有单击事件处理程序的关闭按钮。除了DOM表示(HTML)之外,该对象还将具有JavaScript对象表示(变量和方法)。这是我尝试过的一种方法:////Windowclass//varWindow=function(params){this.testMethod=function(){console.log('te

javascript - 处理 API 设计和 OO 糖

入门读物:Prototypesas"classes"OOJS按照上述模式,我创建如下库/APIvarProto={constructor:function(){this.works=true;},method:function(){returnthis.works;}};现在库用户要与我的原型(prototype)(不提供工厂函数)交互,他们必须实例化和初始化对象//instantiatevarp=Object.create(Proto);//initializep.constructor();这是一种强制用户实例化和初始化我的对象的不友好且冗长的方式。我个人使用pd在我所有的应用程序

javascript - 如何使用datatables(jquery datagrid plugin)实现全选删除功能?

我正在使用jquery插件Datatables来操作我的行实际上它有一个允许checkall功能的tabletools插件,但是,我可以检查所有项目/检查多项,但是如何添加删除按钮并返回所选行?我已经有了删除的sql查询和删除警告弹框的功能。谢谢SelectallindatatableDocumentonhowtoretrieverow,butistilldon'tunderstandhowtodothis,thankyou$(document).ready(function(){$('#viewSub').dataTable({"sDom":'Tlfrtip',"oTableTool

javascript - Bootstrap Material 设计无法在动态 Angular View 中正常工作

我将material-bootstrap脚本包含在我的Angular项目的index.html中,但它们需要手动重新包含在View中才能工作。这很奇怪,因为对于插入到Angular中的所有其他脚本来说,这不会发生。index.html我还注意到material-bootstrap不能很好地与Grunt和Bower配合使用,并且往往会在构建时自行删除(因此手册包含在页面底部)。这些是Material-boostrap和Angular/Bower/Grunt的已知错误还是我做错了什么?如果您还需要什么,请告诉我!编辑:bower.json中的依赖"dependencies":{"angul

javascript - 使用 canvg 将 C3.js SVG 可视化到 Canvas - 折线图填充黑色矩形, "ERROR: Element ' parsererror' 尚未实现”

我正在尝试使用Canvg将SVG转换为Canvas。这是jsfiddle.我收到一条错误消息,“错误:元素‘parsererror’尚未实现”。我可以理解canvg库无法解析SVG元素。但是,这个问题有解决办法吗?我需要从svg元素创建一个Canvas元素。SaveCanvas:varchart={};chart=c3.generate({bindto:'#chart',data:{xs:{'data1':'x1','data2':'x2',},columns:[['x1','2013-01-0103:11:37','2013-01-0203:11:37','2013-02-0303:

javascript - 正则表达式实现负号的奇偶规则

我想用JavaScript编写一个.replace函数来实现代数中负号的奇偶规则。在一系列的消极和积极的迹象中:情况一:如果负号的个数为奇数,则相当于一个负号情况2:如果有偶数个负号,则相当于正号。然后我会执行.replace(/regexforcase1/,"-")和.replace(/regexforcase2/,"+")。关于如何执行此操作的任何想法?以下是示例字符串:\frac{a^{n+-m}}{b}->\frac{a^{n-m}}{b}abc+cde=ghj--+--hsnj->abc+cde=ghj+hsnj 最佳答案

javascript - 将 Observables 实现到持久队列库中

目前正在编写一个小型持久队列库,用于将行读取/写入文本文件。这是添加方法,例如:Queue.prototype.add=function(line,cb){getLock(this,err=>{if(err){this.emit('error',err);releaseLock(err,cb);}else{fs.appendFile(this.filepath,line,err=>{err&&this.emit('error',err);releaseLock(err,cb);});}});};我觉得很尴尬的是支持事件发射器和回调(或事件发射器和promise)。换句话说,对于队列中的

javascript - 使用箭头键和智能延迟加载实现有机列表浏览

简单场景我有一个列表,我实现了使用箭头键(向上、向下)进行浏览,并且在当前列表项的每次更改时,都会通过AJAX加载一个数据库对象。甜蜜的。问题当用户快速浏览列表时,我不希望每个请求都关闭。但当然,最初的请求应该立即关闭。我的想法是使用变量作为延迟来设置超时,并在项目初始加载后增加该变量。这行得通,但是当用户暂时停止浏览但随后继续浏览时,我仍然不希望每个请求都关闭。所以我想,延迟变量必须随着每次浏览事件而合理增加,直到达到阈值。这种有机的方法将成功地减少不必要的元素加载量。我的解决方案我来得很远。这段代码(下面的解释)将完成这项工作,有一个主要罪魁祸首:第一次浏览完成然后停止后,延迟将自

javascript - 实现 COMET 客户端

我已经了解了什么是COMET流式传输,以及让它在主要浏览器上运行所需的所有各种技巧。遇到的问题好像是两方面的:1.服务器能够支持很多持久连接2.实现JS功能我有一个需要执行COMET流式处理的应用程序。我已经解决了上面的第一个问题-我有一个运行的自定义服务器,它在更新到达时提供block。我希望现在能够使用JS连接到此URL,以便接收更新。是否有一个简单的COMET库可供我使用?我看到了Orbited项目。我可以使用orbited的客户端JS来执行此操作吗?为此,我需要在后端执行哪些修改? 最佳答案 如果您可以让您的服务器代码符合B

JavaScript inflate 实现(可能仅限 FF 3.6)

我正在编写一些使用FireFox3.6中的HTML5文件API的脚本。我有一些放气(压缩)的文件,我需要扩充(解压缩)它们。我找到了一个fewscripts虽然谷歌搜索,但他们都没有测试。所以我有点不愿意使用它们。我的问题是:浏览器可以膨胀。我可以通过伪造XHR请求以某种方式搭载通货膨胀吗?或者以任何其他方式搭载?请记住,该脚本目前是FireFox3.6独有的。不过,它不能是扩展程序,我希望它是一个常规网页。或者,您知道有没有为它编写测试的脚本? 最佳答案 我找到了anexistinglibrary.写了一个测试。将它包装在一个函数