
本文旨在解决 JavaScript 问答网页开发中常见的代码重复问题。通过重构代码,利用三元运算符和函数封装,我们将简化代码逻辑,提高代码的可维护性和可扩展性。最终,你将学会如何避免在类似场景下重复编写相似的代码块,从而提高开发效率。
在开发问答网页时,针对不同的主题(如生物、化学、物理),我们可能会编写相似的代码来处理用户选择的课程和问题数量。 这种重复的代码不仅冗余,而且难以维护。本文将介绍如何通过重构 JavaScript 代码,避免这种代码重复,提高代码的效率和可维护性。
原始代码中使用了多个 if...else if...else 语句来判断用户选择的主题,并根据主题选择相应的数组和课程。 我们可以使用三元运算符来简化这些条件判断。
var array = ($('#myTopic').val() == 'Biology' ? biologyQ : ($('#myTopic').val() == 'Chemistry' ? chemistryQ : physicsQ));
const lessonSelected = ($('#myTopic').val() == 'Biology' ? $('#myBiology').val() : ($('#myTopic').val() == 'Chemistry' ? $('#myChemistry').val() : $('#myPhysics').val()));这段代码使用嵌套的三元运算符,根据 #myTopic 的值选择相应的数组(biologyQ、chemistryQ 或 physicsQ)和课程选择器(#myBiology、#myChemistry 或 #myPhysics)。 这样,我们就避免了使用多个 if...else if...else 语句,使代码更加简洁。
立即学习“Java免费学习笔记(深入)”;
代码中,根据用户选择的课程筛选问题、打乱问题顺序、显示指定数量的问题等逻辑,在不同的主题分支中都是相同的。 我们可以将这些通用逻辑封装成函数,并在需要时调用这些函数。
例如,可以将打乱数组顺序的 shuffle 函数保持不变,因为它是一个通用的算法。
function shuffle(array) {
for (let i = array.length - 1; i > 0; i--) {
let j = Math.floor(Math.random() * (i + 1));
let temp = array[i];
array[i] = array[j];
array[j] = temp;
}
return array;
};将上述优化方法应用到原始代码中,可以得到以下优化后的代码:
$(document).ready(function(){
$('.go-btn').on('click',function() {
var array = ($('#myTopic').val() == 'Biology' ? biologyQ : ($('#myTopic').val() == 'Chemistry' ? chemistryQ : physicsQ));
const lessonSelected = ($('#myTopic').val() == 'Biology' ? $('#myBiology').val() : ($('#myTopic').val() == 'Chemistry' ? $('#myChemistry').val() : $('#myPhysics').val()));
var lessonResult = $.grep(array, function(e){ return e.lesson == lessonSelected; });
{
const array = lessonResult;
function shuffle(array) {
for (let i = array.length - 1; i > 0; i--) {
let j = Math.floor(Math.random() * (i + 1));
let temp = array[i];
array[i] = array[j];
array[j] = temp;
}
return array;
};
const result = shuffle(array);
$('#q1').html(result[0].question);
$('#q2').html(result[1].question);
$('#q3').html(result[2].question);
var currentVal = $('#myNumber').val();
$('.selected').hide().slice(0, currentVal).show();
}
});
});虽然上述代码已经比原始代码简洁了很多,但仍然存在进一步优化的可能性。例如,可以将显示问题的逻辑封装成一个函数,接受问题数组和要显示的问题数量作为参数。 这样,就可以避免在代码中硬编码 #q1、#q2、#q3 等选择器。
此外,如果主题数量非常多,可以考虑使用更灵活的数据结构来存储主题、课程和问题数据,例如使用 JSON 文件或数据库。 这样,就可以避免在代码中硬编码主题和课程信息,使代码更加可配置。
通过使用三元运算符和函数封装,我们成功地避免了 JavaScript 问答网页开发中的代码重复问题。 优化后的代码更加简洁、易于维护和扩展。 在实际开发中,我们应该积极寻找代码中的重复模式,并尝试使用各种重构技巧来消除这些重复,提高代码的质量和效率。
以上就是如何避免代码重复:JavaScript 问答网页优化实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号