• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
    • Questions
    • Teachers
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

121
Views
¿Cómo recupero valores de un marcador de posición adjunto con ID?

Así que hice un botón que crea un marcador de posición de entrada cada vez que se hace clic (limitado a 4). El problema es que estoy usando el método de publicación y haciendo .value en mi código devuelve un TypeError, pero no los marcadores de posición predeterminados (por ejemplo: m1k1). Los ID se crean y son similares a los predeterminados con la excepción de un número que se genera en un bucle for.

Cuando escribo valores solo en los marcadores de posición predeterminados, todo está bien.

dos elementos

 let m1k1 = document.querySelector('#mon1wk1') let m1k2 = document.querySelector('#mon1wk2')

eventListener

 let num = 1 function addWeek(e) { e.preventDefault() num++ let mkInput = document.createElement('input') let forma = document.querySelector('#forma') mkInput.placeholder = " " mkInput.id = 'mon1wk' + num mkInput.type = 'text' forma.append(mkInput) if (num === 4) { addwk1.disabled = true;

Donde los valores se almacenan en un objeto

 pushMonths.firstMonth.Week1 = m1k1.value, pushMonths.firstMonth.Week2 = m1k2.value,

Cualquier ayuda es apreciada

almost 3 years ago · Santiago Trujillo
1 answers
Answer question

0

En el código OP, el num es igual a 1, por lo que cuando la identificación se asigna a una nueva <input> cuando el usuario hace clic en el <button> , la primera <input> se asigna id="mon1wk1" y la segunda <input> se asigna id="mon1wk2" . Entonces, ahora hay 2 pares de <input> comparten la misma id que no es válida, además de que la id no puede encontrar los duplicados, ya que el navegador deja de buscar tan pronto como encuentra la primera id , lo que explica por qué los <input> estáticos siempre funcionaron.

En el siguiente ejemplo, el objeto sigue el siguiente patrón:

figura yo

 const obj = { mw: [2, 1], // [2nd month, 1st week] mon1: { // Each mon* object can have up to 4 wk* properties wk1: mon1wk1.value, ⇓⇓⇓ wk4: mon1wk4.value }, mon2: { wk1: mon2wk1.value } };

Los detalles se comentan en el ejemplo.

 // Reference <form> const frm = document.forms.forma; /** * @param {object} obj - Used to keep data * @param {array} obj.mw - Keeps count of current * month at mw[0] and week at mw[1] * @param {object} obj.mon* - Month holds 4 weeks * @param {any} obj.wk* - Week holds associated * <input> value */ const obj = { mw: [1, 2], mon1: { wk1: 5, wk2: 4 } }; let m = obj.mw[0]; let w = obj.mw[1]; // Bind submit event to <form> frm.onsubmit = addWeek; function addWeek(e) { // Stop <form> from killing page e.preventDefault(); // Build new <input> let mk = document.createElement('input'); mk.type = 'text'; frm.append(mk); /* Incerment 'w' If 'w' is greater than 4... ...add a new 'mon*' object and assign it a new 'w' *//* Otherwise assign a new property to current 'mon*' Assign id to new <input> with this pattern: `mon${m}wk${w}` */ ++w; if (w > 4) { ++m; w = 1; obj['mon' + m] = { ['wk' + w]: 0 }; obj.mw[0] = m; obj.mw[1] = 1; } else { obj['mon' + m]['wk' + w] = 0; obj.mw[1] += 1; } mk.id = 'mon' + m + 'wk' + w; console.log(obj); } // Bind input event to <form> frm.oninput = saveData; /* When a user inputs a value into an <input>, assign the value to the associated property of obj. The value is coerced into a number: +mk.value Remove the '+' if you want string instead. */ function saveData(e) { const mk = e.target; let id = mk.id; obj[id.slice(0, 4)][id.slice(4)] = +mk.value; console.log(obj); }
 form { display: flex; } button, input { display: inline-block; }
 <form id='forma'> <button id='addWk'>Add Week</button><br><hr> <input id='mon1wk1' value='5'> <input id='mon1wk2' value='4'> </form>

almost 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error