javascript - 将多个javascript函数合并为一个

标签 javascript merge coding-style

我有这两个 javascript 函数,希望将它们“合并”为一个。 稍后我将添加更多这些转换函数,并希望它比仅仅复制函数更简单、更清晰。

<!--Convert kg in pnd-->
<script type="text/javascript">
function init(){
document.getElementById('kg').onmouseup=function() {
if(isNaN(this.value)) {
   alert('numbers only!!');
   document.getElementById('kg').value='';
   document.getElementById('pnd').value='';
   return;
 }
   document.getElementById('pnd').value=(this.value*2.2046).toFixed(1);
  }
 }
if(window.addEventListener){
   window.addEventListener('load',init,false);
 }
else {
if(window.attachEvent){
   window.attachEvent('onload',init);
  }
 }
</script>

<!--Convert cm in feet-->
<script type="text/javascript">
function start(){
document.getElementById('hauteur_cm').onmouseup=function() {
if(isNaN(this.value)) {
   alert('numbers only!!');
   document.getElementById('hauteur_cm').value='';
   document.getElementById('hauteur_pieds').value='';
   return;
 }
   document.getElementById('hauteur_pieds').value=(this.value*0.03280839895).toFixed(1);
  }
 }
if(window.addEventListener){
   window.addEventListener('load',start,false);
 }
else {
if(window.attachEvent){
   window.attachEvent('onload',start);
  }
 }
</script>

感谢帮助

最佳答案

制作一个包含单位对列表的对象:

var unitPairs = [
  { from: 'kg', to: 'pnd', factor: 2.2046 },
  { from: 'hauteur_cm', to: 'hauteur_pieds', factor: 0.03280839895 },
  /* ... */
];

然后你可以编写一个函数来处理所有这些:

function init() {
  for (var i = 0; i < unitPairs.length; ++i) {
    var pair = unitPairs[i];
    document.getElementById(pair.from).onmouseup = function() {
      if (isNaN(this.value)) {
        // ...
      }
      document.getElementById(pair.to).value = (this.value * pair.factor).toFixed(1);
    }
    // ...
  }
}

您还应该使用像 jQuery 这样的框架来为您完成一些事件绑定(bind)工作。

关于javascript - 将多个javascript函数合并为一个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2134005/

相关文章:

javascript - Chrome 认为我的 JavaScript 是普通话

pandas - 合并 Pandas 数据框 : how to add columns and replace values

java - 使用哪种语法可以获得更好的性能和资源利用率

php - 如何修复网络解决方案 ssl 代理的错误

javascript - 使用JavaScript使标题在网页中弹出?

mercurial - 如何 merge 本地存储库中的 2 个分支

c++ - 你为什么要写这样的东西? (故意不在数组上使用 delete [])

java - 在 Java 中你应该总是使用枚举而不是常量吗?

javascript - html5 canvas 旋转文本的错误尺寸

python - 用矢量化方法替换 python for 循环以丢弃丢失的数据