- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我听从了'justkt的建议'和'xtofl '并对我的代码做了一些巨大的改变。我认为这是一个更好的设计,但仍请提供反馈和改进建议。
首先,我创建了一些枚举...
var SymbolName = {
alpha : 0,
beta : 1,
// ... etc...
};
Object.freeze(SymbolName);
var TypeOfSymbol = {
GreekSymbol : 0,
// ... etc...
};
Object.freeze(TypeOfSymbol);
...然后我重构了我的 Symbol
类的方法是取出我之前拥有的所有成员变量,并将其制作成一个对象,该对象可以记住每个 Symbol
4 个值。 ...
function Symbol(name, id, value, type) {
var name = name;
var id = id;
var value = value;
var type = type;
this.getName = function() {
return name;
};
this.getID = function() {
return id;
};
this.getValue = function() {
return value;
};
this.getMathMLTag = function() {
var tag;
switch (Number(type)) {
case TypeOfSymbol.GreekSymbol:
tag = 'mi';
break;
default:
tag = 'mo';
break;
}
return tag;
};
};
现在,创建并访问这些 Symbol
对象,我创建了一个 Symbols
具有所有可能的数组 Symbol
的对象对象...
function Symbols() {
var theSymbols = new Array();
// new Symbol(name, id, value, type)
theSymbols[SymbolName.alpha] = new Symbol('alpha', 'symbol_' + SymbolName.alpha, 'α', TypeOfSymbol.GreekSymbol);
// ... etc...
this.getSymbol = function(symbolID) {
return theSymbols[symbolID];
};
};
所以现在一切都很容易了。我声明一个变量var symbols = new Symbols();
如果我想获得符号,我可以这样做:
symbols.getSymbol(SymbolName.alpha); // get the Symbol object
symbols.getSymbol(SymbolName.alpha).getValue(); // get the Symbol value
symbols.getSymbol(SymbolName.alpha).getID(); // get the Symbol ID
这让我可以轻松创建 <div>
每个Symbol
s很容易:
$.fn.AppendGreekSymbols = function() {
var symbol;
var mathTag;
var openingTags;
var closingTags;
// lower-case Greek Alphabet
var index = SymbolRanges.GreekSymbolsStartIndex;
for (index; index <= SymbolRanges.GreekSymbolsEndIndex; index++) {
symbol = symbols.getSymbol(index);
openingTags = '<div id=\"' + symbol.getID() + '\" class=\"symbol ' + symbol.getName() + '\">';
mathTag = '<math display=\"block\"><' + symbol.getMathMLTag() + '>';
closingTags = '</' + symbol.getMathMLTag() + '></math></div>';
$('.greek-symbols').append(openingTags + mathTag + symbol.getValue() + closingTags);
}
};
此外,我可以为所有 Symbol
定义一键单击处理程序轻松对象:
$(function() {
$('div.symbol').click(function() {
var targetSymbolID = $(this).attr('id').split('_')[1];
var symbol = symbols.getSymbol(targetSymbolID);
$().InsertSymbol(symbol);
});
});
...就是这样!耶!我认为这是一个巨大的改变......我对这个重构过程和我提出的设计感到非常自豪。大家觉得怎么样?
我有一个Symbol
类看起来像这样:
function Symbol() {
// I need to define some functions in here
};
Symbol.prototype.alpha = "α";
Symbol.prototype.Alpha = "A";
Symbol.prototype.beta = "β";
Symbol.prototype.Beta = "B";
Symbol.prototype.gamma = "γ";
Symbol.prototype.Gamma = "Γ";
Symbol.prototype.delta = "δ";
Symbol.prototype.Delta = "Δ";
... and so on for nearly 500 symbols...
每个符号将单独放入其自己的 <div class="symbol alpha">
中元素,但是alpha
将是与符号名称相对应的类名称...所以还有其他类似的元素,例如 <div class="symbol beta">
, <div class="symbol gamma">
等等...所以要做到这一点,我会有很多重复的代码:
var symbol = new Symbol();
$('.greek-symbols').append('<div class="symbol alpha">' + symbol.alpha + '</div>');
$('.greek-symbols').append('<div class="symbol beta">' + symbol.beta + '</div>');
$('.greek-symbols').append('<div class="symbol gamma">' + symbol.gamma + '</div>');
... etc...
现在,我想要做的是为每个符号及其相应的 <div>
设置一个单击事件处理程序容器。同样,我会有很多重复的代码,如下所示:
$('div.symbol.alpha').click(function() {
$().InsertSymbol(symbol.alpha);
});
$('div.symbol.beta').click(function() {
$().InsertSymbol(symbol.beta);
});
... and so on...
我认为有更好的方法来做到这一点。理想情况下,我希望只有一个事件处理程序可以从类中解析出符号名称,在 Symbol
中查找它上课,并以这种方式做事。所以...
$('div.symbol').click(function() {
// I know the following code doesn't correctly parse out the correct class,
// I'll worry about that later, but the idea is clear
var symbolName = $(this).attr('class'); // parse out the correct class, the symbol name
$().InsertSymbol(Symbol.getSymbol(symbolName));
});
...以及 Symbol
类,我会有这个getSymbol()
函数将接受一个名称并查找符号并返回正确的符号。但是,我不确定如何在 JavaScript/jQuery 中执行此操作。我该如何建立这个逻辑?我不知道 JavaScript 是否有一个 HashMap 类,就像 Java 那样,那么查找这些符号的好方法是什么?
如果我需要进一步澄清,请告诉我。
附:我欢迎任何有关良好面向对象设计的来源/引用的建议
最佳答案
您可能会从面向对象的方法中受益:如果您定义一个 Symbol
类,它可能会有很多实例,而不是成员变量。
注意:代码尚未经过测试 - 请捕获这个想法。
编辑:jsfiddle位于http://jsfiddle.net/xtofl/ttjZw/4/
// the class:
function Symbol( name, lowname, upcase, lowcase ) {
this.name = name;
this.lowname = lowname;
this.upcase=upcase;
this.lowcase=lowcase;
}
// creates a div - may be done using jQuery DOM functions
Symbol.prototype.makedivs = function() {
return "<div class='"+this->name+"'>"+this.upcase+"</div>"
+"<div class='"+this->lowname+"'>"+this.lowcase+"</div>"
}
Symbol.prototype.addhandler = function() {
var symbol = this;
$(this->name).click()( function(e){ document.write( symbol->upcase ); } );
}
$(document).ready( function() {
// the instances:
var symbols = [
new Symbol( 'alfa', 'Alfa', "α", "α" ),
new Symbol( 'beta', 'Beta', "α", "α" ),
//...
];
for( var i = 0; i != symbols.length; ++i ) {
symbols[i].addhandler();
}
});
关于javascript - 我如何重构这段代码以使其更加面向对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5234309/
我正在创建一个多区域 AlwaysOn Sql Availability 组。我在东部有 2 个虚拟机,在西部有 1 个虚拟机。我需要使用面向公众的负载平衡器对这些进行负载平衡。是否可以使用存在于不同
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是 Smalltalk 技术的新手。我的编程经验是使用 C 和 C++。我想了解smalltalk的设计方法论。谁能推荐一些用smalltalk开发的简单的实时应用程序,可以帮助像我这样的初学者探索
现在我已经对 web2py 比较熟悉了,我想试试 Django。 主要区别是什么? 考虑到 web2py 知识,最有效的入门方法是什么? (一定有一些python应用框架的知识,不是吗?) 编辑 另外
我之前发过一个问题,Moving away from VSS ,其中我向使用 VSS 的 Delphi 开发人员询问了最佳的 VCS 控件。大多数开发人员似乎将 svn 与 TortoiseSVN 一
引用this question ,收集对 Delphi 初学者真正有帮助的网站链接可能会很好。 第一个答案指向Delphi Basics ,这是一个非常好的网站。 但一定还有更多。 所以:请为这个社区
我已经构建了一个 saas 产品,其中 Angular 4 与 golang Rest api 集成,并将构建上传到了 aws ec2 实例上。我的项目是一个基于 Multi-Tenancy 的应用程
我是 .NET 开发人员,在此之前使用过 VB6。我已经非常熟悉这些环境,并在垃圾收集语言的上下文中工作。但是,我现在希望通过 native C++ 增强我的技能,但发现自己有点不知所措。具有讽刺意味
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
由于我在数学方面没有任何出色的技能,所以我问您是否存在我应该在未来可能会改变的类(class)中使用的算法。 考虑以下场景: “角色”类具有以下字段: private boolean admin; p
我有许多面向“列”的 csv 文件,我需要对其进行预处理才能最终索引它们。 这是面向时间的数据,每个“设备”都有大量的列(最多 128 列),例如: LDEV_XXXXXX.csv
我想就重构技巧的最佳资源展开讨论,着眼于前端 JavaScript 重构。 一个我尊重其意见的 friend 建议这个 book ,尽管它使用 Java 中的示例。我明白 OO 重构的原则应该翻译成另
我不明白如何使用 Jquery/javascript 处理对象。 以及如何创建私有(private)方法/变量?我在论坛上看到关闭,但我尝试过但没有用。以及如何查看方法/变量是否是私有(private
我已经使用 MATLAB 多年并且非常熟练。我习惯了 MATLAB 调试,您可以在其中跳过行并查看变量及其变化方式,这就是我学习编码的方式。我现在正在研究使用 FORTRAN、C++ 和 Python
我正在学习如何实现“单一 Activity - 多个 fragment ”架构。据我所知,这是如今很普遍的方法,你可以找到很多关于这个主题的文章。例如这个 http://vinsol.com/blog
目前是否有任何简单的方法可以在 Apache Tomcat Servlet 容器前面设置 YAWS Web 服务器,类似于流行的 Apache httpd + Tomcat 设置? 最佳答案 我不相信
我是一个相当有能力的 Ruby 脚本编写者/程序员,但一直感到要扩展到 C++ 的压力。我没能找到任何与“C++ for Ruby Programmers”相关的网站。 This site Pytho
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我在表上有一个名为 cart_product_fti 的全文索引 每当我使用它时,我都必须准确列出索引中的所有字段: MATCH (foo,bar,etc) 我的想法是,如果稍后我决定向索引添加/删除
我是一名优秀的程序员,十分优秀!