जवाबों:
गोल्फरों के लिए मेरे 2 सेंट:
b="1,2,3,4".split`,`.map(x=>+x)
बैकक्वॉट स्ट्रिंग लिटिरल है इसलिए हम कोष्ठक (विभाजन कार्य की प्रकृति के कारण) को छोड़ सकते हैं लेकिन यह बराबर है split(',')। स्ट्रिंग अब एक सरणी है, हमें बस स्ट्रिंग के पूर्णांक को वापस करने वाले फ़ंक्शन के साथ प्रत्येक मान को मैप करना होगा x=>+x(जो कि Numberफ़ंक्शन से भी कम है (6 के बजाय 5 चार्ट)) के बराबर है:
function(x){return parseInt(x,10)}// version from techfoobar
(x)=>{return parseInt(x)} // lambda are shorter and parseInt default is 10
(x)=>{return +x} // diff. with parseInt in SO but + is better in this case
x=>+x // no multiple args, just 1 function call
मुझे उम्मीद है कि यह थोड़ा और स्पष्ट है।
आप Array.mapप्रत्येक तत्व को संख्या में बदलने के लिए उपयोग कर सकते हैं ।
var a = "1,2,3,4";
var b = a.split(',').map(function(item) {
return parseInt(item, 10);
});
डॉक्स की जाँच करें
या अधिक सुरुचिपूर्ण ढंग से उपयोगकर्ता द्वारा इंगित किया गया: thg435
var b = a.split(',').map(Number);
Number()बाकी काम कहां होगा: यहां देखें
नोट: पुराने ब्राउज़रों के लिए जो समर्थन नहीं करते हैं map, आप अपने आप को एक कार्यान्वयन जोड़ सकते हैं जैसे:
Array.prototype.map = Array.prototype.map || function(_x) {
for(var o=[], i=0; i<this.length; i++) {
o[i] = _x(this[i]);
}
return o;
};
map(Number)।
"1.1,2,3".split(",").map(Number)है [1.1, 2, 3]जबकि "1.1,2,3".split(",").map(item => parseInt(item, 10))है[1, 2, 3]
इसे पूर्णांक पर मैप करें:
a.split(',').map(function(i){
return parseInt(i, 10);
})
mapहर ऐरर आइटम को देखता है, इसे दिए गए फंक्शन में पास करता है और एरे को उस फंक्शन के रिटर्न मान के साथ देता है। mapपुराने ब्राउज़रों में उपलब्ध नहीं है, लेकिन jQuery या अंडरस्कोर जैसे अधिकांश पुस्तकालयों में क्रॉस-ब्राउज़र संस्करण शामिल है।
या, यदि आप लूप पसंद करते हैं:
var res = a.split(",");
for (var i=0; i<res.length; i++)
{
res[i] = parseInt(res[i], 10);
}
विवरण के लिए Array.from () MDN पर जाएं
var a = "1,2,3,4";
var b = Array.from(a.split(','),Number);
b एक संख्या है
एक और छोटा समाधान: नक्शा और तर्क पास करने के लिए Number:
var a = "1,2,3,4";
var b = a.split(',');
console.log(b);
var c = b.map(Number);
console.log(c);
एक संस्करण के रूप में आप लॉजिश लाइब्रेरी से जुडाव_.map और _.aryतरीकों का उपयोग कर सकते हैं । संपूर्ण परिवर्तन अधिक कॉम्पैक्ट होगा। यहाँ आधिकारिक दस्तावेज से उदाहरण दिया गया है :
_.map(['6', '8', '10'], _.ary(parseInt, 1));
// → [6, 8, 10]
लैम्ब्डा और / या का उपयोग करने के लिए radixपैरामीटर देने की कोई आवश्यकता नहीं है parseInt, बस उपयोग करें parseFloatया Numberइसके बजाय।
कारण:
यह काम कर रहा है:
var src = "1,2,5,4,3";
var ids = src.split(',').map(parseFloat); // [1, 2, 5, 4, 3]
var obj = {1: ..., 3: ..., 4: ..., 7: ...};
var keys= Object.keys(obj); // ["1", "3", "4", "7"]
var ids = keys.map(parseFloat); // [1, 3, 4, 7]
var arr = ["1", 5, "7", 11];
var ints= arr.map(parseFloat); // [1, 5, 7, 11]
ints[1] === "5" // false
ints[1] === 5 // true
ints[2] === "7" // false
ints[2] === 7 // trueयह छोटा है।
यह एक छोटा सा तेज है और कैश का फायदा उठाता है, जब parseInt-approach - नहीं :
// execution time measure function
// keep it simple, yeah?
> var f = (function (arr, c, n, m) {
var i,t,m,s=n();
for(i=0;i++<c;)t=arr.map(m);
return n()-s
}).bind(null, "2,4,6,8,0,9,7,5,3,1".split(','), 1000000, Date.now);
> f(Number) // first launch, just warming-up cache
> 3971 // nice =)
> f(Number)
> 3964 // still the same
> f(function(e){return+e})
> 5132 // yup, just little bit slower
> f(function(e){return+e})
> 5112 // second run... and ok.
> f(parseFloat)
> 3727 // little bit quicker than .map(Number)
> f(parseFloat)
> 3737 // all ok
> f(function(e){return parseInt(e,10)})
> 21852 // awww, how adorable...
> f(function(e){return parseInt(e)})
> 22928 // maybe, without '10'?.. nope.
> f(function(e){return parseInt(e)})
> 22769 // second run... and nothing changes.
> f(Number)
> 3873 // and again
> f(parseFloat)
> 3583 // and again
> f(function(e){return+e})
> 4967 // and again
> f(function(e){return parseInt(e,10)})
> 21649 // dammit 'parseInt'! >_<सूचना: फ़ायरफ़ॉक्स में parseIntलगभग 4 गुना तेजी से काम होता है, लेकिन फिर भी यह दूसरों की तुलना में धीमा है। कुल में: +e< Number< parseFloat<parseInt
मैट ज़ुंटर्ट का संस्करण जिसका उपयोग arraw function (ES6) के साथ है
const nums = a.split(',').map(x => parseInt(x, 10));
एक लाइन
Array.from(a.split(','), Number)
चूंकि सभी उत्तर NaNशामिल किए जाने की अनुमति देते हैं, मैंने सोचा कि मैं यह जोड़ना चाहूंगा कि यदि आप संख्याओं के लिए मिश्रित मूल्यों की एक सरणी को जल्दी से डालना चाहते हैं तो आप कर सकते हैं।
var a = "1,2,3,4,foo,bar";
var b = a.split(',');
var result = b.map(_=>_|0) // Floors the number (32-bit signed integer) so this wont work if you need all 64 bits.
// or b.map(_=>_||0) if you know your array is just numbers but may include NaN.