21.11.2014, 22:40
|
Профессор
|
|
Регистрация: 09.11.2014
Сообщений: 610
|
|
Сообщение от devote
|
ну было бы странно если бы он работал быстрее.. Он же на каждую итерацию вызывает функцию, а вызов функции пожирает большие ресурсы.
|
Навряд ли в этом дело. Скорей, в кривости реализации.
Array.prototype.foreach=function(f){
for(var i=0; i<this.length; i++) f(this[i])
}
arr=[]
i=10000
while(i--){arr.push(i)}
tst=function(x){return x + 1}
console.time("forEach")
arr.forEach(tst)
console.timeEnd("forEach")
console.time("foreach")
arr.foreach(tst)
console.timeEnd("foreach")
// forEach: 58ms
// foreach: 1ms
|
|
22.11.2014, 00:07
|
что-то знаю
|
|
Регистрация: 24.05.2009
Сообщений: 5,176
|
|
Сообщение от krutoy
|
Скорей, в кривости реализации.
|
не в кривости а в требованиях, оригинальная реализация выглядит примерно так:
Array.prototype.foreach = function (callback, thisArg) {
var T, k;
if (this == null) {
throw new TypeError(' this is null or not defined');
}
// 1. Положим O равным результату вызова ToObject passing the |this| value as the argument.
var O = Object(this);
// 2. Положим lenValue равным результату вызова внутреннего метода Get объекта O с аргументом "length".
// 3. Положим len равным ToUint32(lenValue).
var len = O.length >>> 0;
// 4. Если IsCallable(callback) равен false, выкинем исключение TypeError.
// Смотрите: [url]http://es5.github.com/#x9.11[/url]
if (typeof callback !== 'function') {
throw new TypeError(callback + ' is not a function');
}
// 5. Если thisArg присутствует, положим T равным thisArg; иначе положим T равным undefined.
if (arguments.length > 1) {
T = thisArg;
}
// 6. Положим k равным 0
k = 0;
// 7. Пока k < len, будем повторять
while (k < len) {
var kValue;
// a. Положим Pk равным ToString(k).
// Это неявное преобразование для левостороннего операнда в операторе in
// b. Положим kPresent равным результату вызова внутреннего метода HasProperty объекта O с аргументом Pk.
// Этот шаг может быть объединён с шагом c
// c. Если kPresent равен true, то
if (k in O) {
// i. Положим kValue равным результату вызова внутреннего метода Get объекта O с аргументом Pk.
kValue = O[k];
// ii. Вызовем внутренний метод Call функции callback с объектом T в качестве значения this и
// списком аргументов, содержащим kValue, k и O.
callback.call(T, kValue, k, O);
}
// d. Увеличим k на 1.
k++;
}
// 8. Вернём undefined.
};
arr=[]
i=10000
while(i--){arr.push(i)}
tst=function(x){return x + 1}
console.time("forEach")
arr.forEach(tst)
console.timeEnd("forEach")
console.time("foreach")
arr.foreach(tst)
console.timeEnd("foreach")
// Chrome:
// forEach: 1.000ms
// foreach: 1.000ms
|
|
22.11.2014, 09:30
|
|
Профессор
|
|
Регистрация: 11.09.2010
Сообщений: 8,804
|
|
Сообщение от klk.pma
|
Number не во всех браузерах работает
|
Во всех. Даже в IE5.5
Сообщение от krutoy
|
Да не, они просто домохались до for in, якобы, он медленный
|
Дело не в скорости. Дело в говнистости кода ) Говнокодерам без разницы как писать.
Для наитупейшего обхода элементов массива задействовать машину регулярных выражений - это победа .
__________________
В личку только с интересными предложениями
Последний раз редактировалось danik.js, 22.11.2014 в 09:36.
|
|
22.11.2014, 10:25
|
Интересующийся
|
|
Регистрация: 30.06.2014
Сообщений: 23
|
|
Сообщение от danik.js
|
Во всех. Даже в IE5.5 .
|
С каких это пор html5 работает в ie5 и уж тем более в ie 5.5 ))
|
|
23.11.2014, 10:38
|
Профессор
|
|
Регистрация: 23.10.2010
Сообщений: 2,718
|
|
Сообщение от klk.pma
|
Если есть один input, то это можно реализовать через это:
|
Через это
form.addEventListener('input',validate);
и вперде
в инпуте есть тип - тот самый number. Если брауз - копенгаген, то все само будет работать, а если туп - то вы берете getAttribute('type') и получаете number и, соответственно, проверяете по своему любимому паттерну.
Это геморройный способ сугубой сраной оптимизации. Легкая избыточность данных существенно все облегчает - х на type, он вообще может быть любым - пишите в pattern свой паттерн и JS вам проверит все что угодно по этому паттерну. Ну, если бразуер тупит.
|
|
23.11.2014, 10:47
|
Профессор
|
|
Регистрация: 23.10.2010
Сообщений: 2,718
|
|
Так вот, у меня тоже есть вопрос - а возможно ли перевести взад на человеческий язык криптографию регулярного выражения?
Например
if(len && input.pattern && !new RegExp(input.pattern).test(value))
throw 'Здесь '+input.errmsg;
Чтобы сообщить что-то осмысленное, а не просто типа "введите перпендикулярно", приходится в том же месте откуда берутся паттерны задавать сообщения об ошибках проверки по паттерну - errmsg.
А было бы круто чтобы программа сама, разобралась в требованиях шаблона проверки и написала, типа: Здесь минимум 3 символа, которые должны быть все печатными.
|
|
23.11.2014, 10:58
|
Профессор
|
|
Регистрация: 23.10.2010
Сообщений: 2,718
|
|
Сообщение от krutoy
|
и введет при этом нецифровой символ
|
Это признак слабости ума разраба - вписывать юзера в свою историю болезни. Не понимая что делать с ошибочным вводом, не имея налаженной системы прерываний по ошибкам - разраб бросается на амбразуру всем телом пытаясь перекрыть кислородо юзеру.
Понятно откуда ноги воняют? На фронтире, типа, усе сразу получить _правильно_ и тогда налаживать обратную связь и не надо. Лафа!
Так вот вполне понятно что без всякого текстового поля можно обойтись и захерачить ему какие хочешь нахуй буквы вместо цифр и посмотреть как сервер чмокнет.
ЗЫ Не должен js заниматься санитарией. Потому что обойти его ленточки - как два пальца об асфальт. Вся санитария будет только на сервере, который и сообщит что юзер ввел не перпедикулярно. JS может только проверить и написать что ввели хуйню, по сему факту задизаблить сабмит формы и все такое. Но корежить данные - не должен. Что отправилось - на то сервер только отвечает.
Последний раз редактировалось kostyanet, 23.11.2014 в 11:04.
|
|
|
|