计数器应用程序:按钮函数以触发各种消息

发布于 2025-02-07 04:27:57 字数 2549 浏览 1 评论 0原文

我正在使用Vanilla JavaScript构建乘客计数器应用程序,并试图围绕单击HTML DOM对象按钮时如何将我的头围绕着我要根据计数的位置来更改我要输出的消息。

我有一个增加和减小的按钮,将计数增加或减少1。每辆总线具有不同的乘客能力,因此我将每三个公共汽车都放在Navbar中(DDS,DDSB,MCI)。例如,在单击“ DDS”时,我希望相对于计数的位置调用特定消息。同样适用于其他公交车型。

let messageEl = document.getElementById("message-el")
let countEl = document.getElementById("count-el")
let ddsNavEl = document.getElementById("dds-nav-el")
let ddsbNavEl = document.getElementById("ddsb-nav-el")
let mciNavEl = document.getElementById("mci-nav-el")
let increaseEl = document.getElementById("increase-btn")
let decreaseEl = document.getElementById("decrease-btn")
let increaseFiveEl = document.getElementById("increaseFive-btn")
let decreaseFiveEl = document.getElementById("decreaseFive-btn")
var count = 0

/* BASIC COUNTER FUNCTIONALITY WITH NO SEATING LIMIT WARNINGS */
function increase() {
    count++
    countEl.textContent = count
}

function decrease() {
    count--
    countEl.textContent = count
}

function increaseFive() {
    count += 5
    countEl.textContent = count
}

function decreaseFive() {
    count -= 5
    countEl.textContent = count
}

function reset() {
    messageEl.textContent = "";
    countEl.textContent = 0
    count = 0
    ddsNavEl.style.fontWeight = "normal";
    ddsbNavEl.style.fontWeight = "normal";
    mciNavEl.style.fontWeight = "normal";
} 


/* COUNTER WITH SEATING AND STANDING LIMIT WARNINGS */

function ddsSelect() {

    if (count === 15) {
        message = "you are at full seating capacity"
    } else if (count > 16) {
        message = "you are over capacity"
    } else {
        message = ""
    }
    messageEl.textContent = message
    
    ddsNavEl.style.fontWeight = "bold";
    ddsbNavEl.style.fontWeight = "normal";
    mciNavEl.style.fontWeight = "normal";
}

function ddsbSelect() {

    if (count === 12) {
        message = "you are at full seating capacity"
    } else if (count > 13) {
        message = "you are over capacity"
    } else {
        message = ""
    }
    messageEl.textContent = message

    ddsbNavEl.style.fontWeight = "bold";
    ddsNavEl.style.fontWeight = "normal";
    mciNavEl.style.fontWeight = "normal";
}

function mciSelect() {
    
    if (count === 10) {
        message = "you are at full seating capacity"
    } else if (count > 11) {
        message = "you are over capacity"
    } else {
        message = ""
    }
    messageEl.textContent = message

    mciNavEl.style.fontWeight = "bold";
    ddsNavEl.style.fontWeight = "normal";
    ddsbNavEl.style.fontWeight = "normal";
}

I'm building a passenger counter application for buses with vanilla javascript and I'm trying to wrap my head around how, when clicking a HTML DOM Object button, will alter the messages I want to output based on where the count is.

I have an increase and decrease button that increase or decrease the count by 1. Each bus has different passenger capacities, so I've placed each three busses in the navbar (dds, ddsb, mci). When clicking "dds" for example, I want specific messages to be called relative to where the count is. Likewise for other bus models.

let messageEl = document.getElementById("message-el")
let countEl = document.getElementById("count-el")
let ddsNavEl = document.getElementById("dds-nav-el")
let ddsbNavEl = document.getElementById("ddsb-nav-el")
let mciNavEl = document.getElementById("mci-nav-el")
let increaseEl = document.getElementById("increase-btn")
let decreaseEl = document.getElementById("decrease-btn")
let increaseFiveEl = document.getElementById("increaseFive-btn")
let decreaseFiveEl = document.getElementById("decreaseFive-btn")
var count = 0

/* BASIC COUNTER FUNCTIONALITY WITH NO SEATING LIMIT WARNINGS */
function increase() {
    count++
    countEl.textContent = count
}

function decrease() {
    count--
    countEl.textContent = count
}

function increaseFive() {
    count += 5
    countEl.textContent = count
}

function decreaseFive() {
    count -= 5
    countEl.textContent = count
}

function reset() {
    messageEl.textContent = "";
    countEl.textContent = 0
    count = 0
    ddsNavEl.style.fontWeight = "normal";
    ddsbNavEl.style.fontWeight = "normal";
    mciNavEl.style.fontWeight = "normal";
} 


/* COUNTER WITH SEATING AND STANDING LIMIT WARNINGS */

function ddsSelect() {

    if (count === 15) {
        message = "you are at full seating capacity"
    } else if (count > 16) {
        message = "you are over capacity"
    } else {
        message = ""
    }
    messageEl.textContent = message
    
    ddsNavEl.style.fontWeight = "bold";
    ddsbNavEl.style.fontWeight = "normal";
    mciNavEl.style.fontWeight = "normal";
}

function ddsbSelect() {

    if (count === 12) {
        message = "you are at full seating capacity"
    } else if (count > 13) {
        message = "you are over capacity"
    } else {
        message = ""
    }
    messageEl.textContent = message

    ddsbNavEl.style.fontWeight = "bold";
    ddsNavEl.style.fontWeight = "normal";
    mciNavEl.style.fontWeight = "normal";
}

function mciSelect() {
    
    if (count === 10) {
        message = "you are at full seating capacity"
    } else if (count > 11) {
        message = "you are over capacity"
    } else {
        message = ""
    }
    messageEl.textContent = message

    mciNavEl.style.fontWeight = "bold";
    ddsNavEl.style.fontWeight = "normal";
    ddsbNavEl.style.fontWeight = "normal";
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

半岛未凉 2025-02-14 04:27:57

我没有在此示例中包含您的所有功能,但是从本质上讲,我认为最好的方法是创建一个对象并根据其类型或某种形式的ID进行实例化。您在示例中提到,总线有三种类型...“ DDS,DDSB和MCI”,但实际上,通过使用此技术,您可以简单地实例化对象的实例,如果您需要在某个时候设置另一个总线未来。

下面的示例,所有这些功能都可以设置以接受HTML元素以更新各种接口元素。这些都不包括,因为没有提供。

let bus = {
  passengers: 0,
  increase: function() {
    this.passengers++;
    console.log(this.passengers);
  },
  decrease: function() {
    this.passengers--;
    console.log(this.passengers);
  },
  increaseFive: function() {
    this.passengers += 5;
    console.log(this.passengers);
  },
  decreaseFive: function() {
    this.passengers -= 5;
    console.log(this.passengers);
  }
};

// bus types dds, ddsb, mci

let ddsBus = Object.create(bus);

ddsBus.increase();
ddsBus.increaseFive();

let ddsbBus = Object.create(bus);

ddsbBus.increase();
ddsbBus.increaseFive();
ddsbBus.increase();

let mciBus = Object.create(bus);

mciBus.increase();
mciBus.increaseFive();
mciBus.increase();
mciBus.increase();

console.log("dds : " + ddsBus.passengers);    //expected value: 6
console.log("ddsb : " + ddsbBus.passengers);  //expected value: 7
console.log("mci : " + mciBus.passengers);    //expected value: 8

I didn't include all of your functions in this example, but essentially I think the best way to do this would be to create an object and instantiate it per bus, either based on its type or id of some kind. You mentioned in your example that there were three types of bus... "dds, ddsb, and mci" but essentially by using this technique you could simply instantiate more instances of the object if you needed to setup another bus at some point in the future.

Example below, all of these functions could be setup to accept html elements to update various interface elements. None of that is included because none of it was provided.

let bus = {
  passengers: 0,
  increase: function() {
    this.passengers++;
    console.log(this.passengers);
  },
  decrease: function() {
    this.passengers--;
    console.log(this.passengers);
  },
  increaseFive: function() {
    this.passengers += 5;
    console.log(this.passengers);
  },
  decreaseFive: function() {
    this.passengers -= 5;
    console.log(this.passengers);
  }
};

// bus types dds, ddsb, mci

let ddsBus = Object.create(bus);

ddsBus.increase();
ddsBus.increaseFive();

let ddsbBus = Object.create(bus);

ddsbBus.increase();
ddsbBus.increaseFive();
ddsbBus.increase();

let mciBus = Object.create(bus);

mciBus.increase();
mciBus.increaseFive();
mciBus.increase();
mciBus.increase();

console.log("dds : " + ddsBus.passengers);    //expected value: 6
console.log("ddsb : " + ddsbBus.passengers);  //expected value: 7
console.log("mci : " + mciBus.passengers);    //expected value: 8

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文