Managing more than one slider in HTML 管理多个滑块在HTML中

huangapple go评论69阅读模式
英文:

Managing more than one slider in HTML

问题

I'm new to html and recognize this may be a basic question. However I haven't been able to find any examples of this sort of functionality yet. I'm trying to do math with the input from two different sliders. Thus far, my code looks like this:

function f(x, y) {
  return x + y
}

function sliderx(value) {
  val = f(value, 1.0)
  console.log(val)
}
<h1> Slider Test</h1>
<div id="myDiv"></div>
<p> sliderx </p>
<form oninput="amount.value=rangeInput.value">
  <input type="range" id="rangeInput" name="rangeInput" step="0.05" min="0.0" max="1.0" value="get_min() " oninput="sliderx(this.value)">
  <output name="amount" for="rangeInput"></output>
</form>
<p> slidery </p>
<form oninput="amount.value=rangeInput.value">
  <input type="range" id="rangeInput" name="rangeInput" step="0.05" min="0.0" max="1.0" value="get_min() " oninput="slidery(this.value)">
  <output name="amount" for="rangeInput"></output>
</form>

I created two sliders (sliderx and slidery) and defined f(x,y) = x+y. My goal is to be able to print x+y to console.log. I can call sliderx and my console updates accordingly for fixed y. However, I don't see any good way to update y using slidery, while keeping x defined by sliderx. Is there any way to do this?

英文:

I'm new to html and recognize this may be a basic question. However I haven't been able to find any examples of this sort of functionality yet. I'm trying to do math with the input from two different sliders. Thus far, my code looks like this:

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

function f(x, y) {
  return x + y
}

function sliderx(value) {
  val = f(value, 1.0)
  console.log(val)
}

<!-- language: lang-html -->

&lt;h1&gt; Slider Test&lt;/h1&gt;
&lt;div id=&quot;myDiv&quot;&gt;&lt;/div&gt;
&lt;p&gt; sliderx &lt;/p&gt;
&lt;form oninput=&quot;amount.value=rangeInput.value&quot;&gt;
  &lt;input type=&quot;range&quot; id=&quot;rangeInput&quot; name=&quot;rangeInput&quot; step=&quot;0.05&quot; min=&quot;0.0&quot; max=&quot;1.0&quot; value=&quot;get_min() &quot; oninput=&quot;sliderx(this.value)&quot;&gt;
  &lt;output name=&quot;amount&quot; for=&quot;rangeInput&quot;&gt;&lt;/output&gt;
&lt;/form&gt;
&lt;p&gt; slidery &lt;/p&gt;
&lt;form oninput=&quot;amount.value=rangeInput.value&quot;&gt;
  &lt;input type=&quot;range&quot; id=&quot;rangeInput&quot; name=&quot;rangeInput&quot; step=&quot;0.05&quot; min=&quot;0.0&quot; max=&quot;1.0&quot; value=&quot;get_min() &quot; oninput=&quot;slidery(this.value)&quot;&gt;
  &lt;output name=&quot;amount&quot; for=&quot;rangeInput&quot;&gt;&lt;/output&gt;
&lt;/form&gt;

<!-- end snippet -->

I created two sliders (sliderx and slidery) and defined f(x,y) = x+y. My goal is to be able to print x+y to console.log. I can call silderx and my console updates accordingly for fixed y. However, I don't see any good way to update y using slidery, while keeping x defined by sliderx. Is there any way to do this?

答案1

得分: 2

<h2>是的,有解决您问题的方法!</h2>
<p>为了实现您的目标,您可以定义两个全局变量x和y,用于存储滑块的当前值,并在滑块值更改时更新它们。然后,您可以使用更新后的x和y值计算f(x, y),并将结果记录到控制台。此外,正如您的注释中提到的,ID应该是唯一的,因此请为您的元素使用唯一的ID和名称。请参见:

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-html -->

&lt;!DOCTYPE html&gt;
&lt;html lang=&quot;en&quot;&gt;
  &lt;head&gt;
    &lt;meta charset=&quot;UTF-8&quot; /&gt;
    &lt;meta http-equiv=&quot;X-UA-Compatible&quot; content=&quot;IE=edge&quot; /&gt;
    &lt;meta name=&quot;viewport&quot; content=&quot;width=q, initial-scale=1.0&quot; /&gt;
    &lt;title&gt;Document&lt;/title&gt;
    &lt;title&gt;What&#39;s the date?&lt;/title&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;Slider Test&lt;/h1&gt;
    &lt;div id=&quot;myDiv&quot;&gt;&lt;/div&gt;
    &lt;p&gt;sliderx&lt;/p&gt;
    &lt;form oninput=&quot;amount.value=rangeInputX.value&quot;&gt;
      &lt;input
        type=&quot;range&quot;
        id=&quot;sliderx&quot;
        name=&quot;rangeInputX&quot;
        step=&quot;0.05&quot;
        min=&quot;0.0&quot;
        max=&quot;1.0&quot;
        value=&quot;get_min()&quot;
        oninput=&quot;update()&quot;
      /&gt;
      &lt;output name=&quot;amount&quot; for=&quot;sliderx&quot;&gt;&lt;/output&gt;
    &lt;/form&gt;
    &lt;p&gt;slidery&lt;/p&gt;
    &lt;form oninput=&quot;amount.value=rangeInputY.value&quot;&gt;
      &lt;input
        type=&quot;range&quot;
        id=&quot;slidery&quot;
        name=&quot;rangeInputY&quot;
        step=&quot;0.05&quot;
        min=&quot;0.0&quot;
        max=&quot;1.0&quot;
        value=&quot;get_min()&quot;
        oninput=&quot;update()&quot;
      /&gt;
      &lt;output name=&quot;amount&quot; for=&quot;slidery&quot;&gt;&lt;/output&gt;
    &lt;/form&gt;
    &lt;script&gt;
      // 使用当前起始值初始化您的滑块
      let sliderx = document.getElementById(&quot;sliderx&quot;);
      let slidery = document.getElementById(&quot;slidery&quot;);
      let x = sliderx.value;
      let y = slidery.value;
      console.log(x, y);

      function update() {
        x = parseFloat(sliderx.value);
        y = parseFloat(slidery.value);
        const result = f(x, y);
        console.log(
          ` ${x} (sliderx的值:) + ${y} (slidery的值) = ${result}`
        );
      }

      function f(x, y) {
        return x + y;
      }
    &lt;/script&gt;
  &lt;/body&gt;
&lt;/html&gt;

<!-- end snippet -->

在这个实现中,我们定义了两个全局变量x和y来存储滑块的当前值。每当滑块的值更改时,将调用update函数,该函数会更新x和y的值,计算f(x, y),并将结果记录到控制台。使用滑块输入的oninput属性,每当任一滑块的值更改时都会调用update函数。output元素使用for属性与其对应的滑块输入相关联。

英文:

<h2>Yes, there is a solution for your problem!</h2>
<p>To achieve your goal, you can define two global variables x and y to store the current values of the sliders, and update them whenever the slider values change. Then, you can calculate f(x,y) using the updated values of x and y, and log the result to the console. Also as your comments also mentioned IDs should be unique so stick with unique IDs and names for your elements. See:

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-html -->

&lt;!DOCTYPE html&gt;
&lt;html lang=&quot;en&quot;&gt;
  &lt;head&gt;
    &lt;meta charset=&quot;UTF-8&quot; /&gt;
    &lt;meta http-equiv=&quot;X-UA-Compatible&quot; content=&quot;IE=edge&quot; /&gt;
    &lt;meta name=&quot;viewport&quot; content=&quot;width=q, initial-scale=1.0&quot; /&gt;
    &lt;title&gt;Document&lt;/title&gt;
    &lt;title&gt;What&#39;s the date?&lt;/title&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;Slider Test&lt;/h1&gt;
    &lt;div id=&quot;myDiv&quot;&gt;&lt;/div&gt;
    &lt;p&gt;sliderx&lt;/p&gt;
    &lt;form oninput=&quot;amount.value=rangeInputX.value&quot;&gt;
      &lt;input
        type=&quot;range&quot;
        id=&quot;sliderx&quot;
        name=&quot;rangeInputX&quot;
        step=&quot;0.05&quot;
        min=&quot;0.0&quot;
        max=&quot;1.0&quot;
        value=&quot;get_min()&quot;
        oninput=&quot;update()&quot;
      /&gt;
      &lt;output name=&quot;amount&quot; for=&quot;sliderx&quot;&gt;&lt;/output&gt;
    &lt;/form&gt;
    &lt;p&gt;slidery&lt;/p&gt;
    &lt;form oninput=&quot;amount.value=rangeInputY.value&quot;&gt;
      &lt;input
        type=&quot;range&quot;
        id=&quot;slidery&quot;
        name=&quot;rangeInputY&quot;
        step=&quot;0.05&quot;
        min=&quot;0.0&quot;
        max=&quot;1.0&quot;
        value=&quot;get_min()&quot;
        oninput=&quot;update()&quot;
      /&gt;
      &lt;output name=&quot;amount&quot; for=&quot;slidery&quot;&gt;&lt;/output&gt;
    &lt;/form&gt;
    &lt;script&gt;
      //Initialize your sliders with current start values
      let sliderx = document.getElementById(&quot;sliderx&quot;);
      let slidery = document.getElementById(&quot;slidery&quot;);
      let x = sliderx.value;
      let y = slidery.value;
      console.log(x, y);

      function update() {
        x = parseFloat(sliderx.value);
        y = parseFloat(slidery.value);
        const result = f(x, y);
        console.log(
          ` ${x} (Value of sliderx:) + ${y} (Value of slidery) = ${result}`
        );
      }

      function f(x, y) {
        return x + y;
      }
    &lt;/script&gt;
  &lt;/body&gt;
&lt;/html&gt;

<!-- end snippet -->

In this implementation, we define two global variables x and y to store the current values of the sliders. Whenever a slider value changes, the update function is called, which updates the values of x and y, calculates f(x,y), and logs the result to the console. The update function is called whenever either slider value changes, using the oninput attribute of the slider inputs. The output elements are associated with their corresponding slider inputs using the for attribute.

答案2

得分: -1

以下是您要翻译的内容:

function f(x, y) {
  return x + y
}

function sliderx(value) {
  let val = f(value, 1.0)
  console.log(val)
}

function slidery(value) {
  let val = f(value, 1.0)
  console.log(val)
}
<h1>滑块测试</h1>
<div id="myDiv"></div>
<p>sliderx</p>
<form oninput="amount.value=rangeInput.value">
  <input type="range" id="rangeInput" name="rangeInput" step="0.05" min="0.0" max="1.0" value="get_min() " oninput="sliderx(this.value)">
  <output name="amount" for="rangeInput"></output>
</form>
<p>slidery</p>
<form oninput="amountY.value=rangeInputY.value">
  <input type="range" id="rangeInputY" name="rangeInputY" step="0.05" min="0.0" max="1.0" value="get_min() " oninput="slidery(this.value)">
  <output name="amountY" for="rangeInputY"></output>
</form>
英文:

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

function f(x, y) {
  return x + y
}

function sliderx(value) {
  let val = f(value, 1.0)
  console.log(val)
}
function slidery(value) {
  let val = f(value, 1.0)
  console.log(val)
}

<!-- language: lang-html -->

&lt;h1&gt; Slider Test&lt;/h1&gt;
&lt;div id=&quot;myDiv&quot;&gt;&lt;/div&gt;
&lt;p&gt; sliderx &lt;/p&gt;
&lt;form oninput=&quot;amount.value=rangeInput.value&quot;&gt;
  &lt;input type=&quot;range&quot; id=&quot;rangeInput&quot; name=&quot;rangeInput&quot; step=&quot;0.05&quot; min=&quot;0.0&quot; max=&quot;1.0&quot; value=&quot;get_min() &quot; oninput=&quot;sliderx(this.value)&quot;&gt;
  &lt;output name=&quot;amount&quot; for=&quot;rangeInput&quot;&gt;&lt;/output&gt;
&lt;/form&gt;
&lt;p&gt; slidery &lt;/p&gt;
&lt;form oninput=&quot;amountY.value=rangeInputY.value&quot;&gt;
  &lt;input type=&quot;range&quot; id=&quot;rangeInputY&quot; name=&quot;rangeInputY&quot; step=&quot;0.05&quot; min=&quot;0.0&quot; max=&quot;1.0&quot; value=&quot;get_min() &quot; oninput=&quot;slidery(this.value)&quot;&gt;
  &lt;output name=&quot;amountY&quot; for=&quot;rangeInputY&quot;&gt;&lt;/output&gt;
&lt;/form&gt;

<!-- end snippet -->

huangapple
  • 本文由 发表于 2023年4月17日 05:47:49
  • 转载请务必保留本文链接:https://go.coder-hub.com/76030492.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定