Фишки JS
Решил для новичков разместить несколько всем хорошо известных
тонкостей.
Пока лишь несколько примеров, попозже добавлю еще
Замыкания - классический пример с массивом
Не то, что ожидаем
var a=[];
for(var i=0;i<100;i++){
a[i]=function(){
alert(i);
}
}
a[1]();//А нет, не 1, а 100
Теперь то, что ожидаем
var a=[];
for(var i=0;i<100;i++){
a[i]=(function(i){
return function(){
alert(i);
}
})(i);
}
a[1]();//1
Короткая запись для new Date().getTime() и new Date().valueOf()
alert(+new Date());
Из строки делаем число без parseInt и Number.
var x = "5";
alert(typeof x);//string
x=+x;
alert(typeof x);//number
Просто примерчик.
alert(0.1+0.2==0.3);//Вовсе не true, а false
alert(0.1+0.2);//0.30000000000000004
alert((0.1+0.2).toFixed(2)==0.3);//true
JSONP, второе название кросс-доменный запрос, применяется для запроса на другой хост.
Название JSONP образовано из ответа сервера в виде
callback1({success:true,params:[{a:1,b:2,c:3}]})
JSON - {success:true,params:[{a:1,b:2,c:3}]}
префикс - callback1.
От слова prefix и взята буква P.
Заметка:
Cтараюсь с сервера не передавать знаки " '.
" и ' - только для строк .
Но у JSON есть свой стандарт, и это считается не верным
{success:true} - не JSON,
{"success":"true"} - JSON.
Для меня JSON - это то, что работает.
<html>
<head>
<title>JSONP</title>
</head>
<script>
function getJSONP(url, callback) {
var cbnum = "cb" + getJSONP.counter++;
var cbname = "getJSONP." + cbnum;
if (url.indexOf("?") === -1){
url += "?jsonp=" + cbname;
}
else{
url += "&jsonp=" + cbname;
}
var script = document.createElement("script");
getJSONP[cbnum] = function(response) {
try{
callback(response);
}
finally {
delete getJSONP[cbnum];
script.parentNode.removeChild(script);
}
};
script.src = url;
document.body.appendChild(script);
}
getJSONP.counter = 0;
window.onload = function(){
var url = 'http://moc-081.ru/jsonp.php?name=Вася',
callback = function(res){
var div = document.createElement('div');
div.innerHTML = "Ответ сервера: "+res.answer;
document.body.appendChild(div);
setTimeout(function(){
getJSONP(url,callback);
},3000);
}
getJSONP(url,callback);
}
</script>
<body>
</body>
</html>
Файл jsonp.php
<?
if(isset($_GET['jsonp']) && isset($_GET['name'])){
echo $_GET['jsonp'].'({success:true,answer:"Привет, '.$_GET['name'].'"})';
}
?>
alert((function RandomString(length) {
var str = '';
for ( ; str.length < length; str += Math.random().toString(36).substr(2) );
return str.substr(0, length);
})(10));
|
Вообще, более корректно эта форма передачи данных называется JSON with Padding. JSON с подкладкой. Не обязательно, чтобы ответ содержал callback prefix, в ответе можно, например, просто объявлять глобальную переменную и всё равно это будет называться jsonp. Под подкладкой понимается сам узел script, в который и загружается код, несущий json. А кроссдоменный запрос - это кроссдоменный запрос и никаким вторым названием не является. Никто не мешает осуществлять jsonp в своей песочнице. Передавать можно любые символы в строке, если специализированные символы прослешировать (\"). В двойных кавычках можно передавать одиночные без слеша, в одиночных - двойные. Ну а то что ты стараешься не передавать - улыбнуло. Автобиография? true, false, null, числа и т.д. не надо помешать в кавычки, вернется строковое значение, а не то, что планировалось. Формат позволяет передавать их без кавычек, сохраняя их природу и ни одна функция защиты от xss не запрещает передавать их как есть. Поражаюсь, откуда ты всё это достаешь? Свои предположения? По тексту видно, что ты слабо представляешь себе, что такое JSON в javascript в принципе. JavaScript object notation, а значит можно описывать структуры точно так же, как это делают непосредственно в javascript.
Представь себе - это тоже json, причем весьма корректный и прекрасно будет работать в jsonp запросе.
Также, сформировалось правило хорошего тона, указывать в querystring свойство ?callback=, тем самым обеспечивая совместимость между сервисами, ты же для новичков вводишь какое-то своё свойство ?jsonp=, зачем? А вообще вся публикация написана в разброс и по большей части - никакими 'фишками' javascript не является, а является обычным здравым смыслом. Большемутво примеров верно для всех языков программирования, поэтому название 'фишки' да еще и 'в javascript' не отражает содержания статьи.
Пример c JSONP взят из книги Дэвида Фленагана.
Который для меня авторитет.
Как писать код решать Вам.
тот пример, который представлен как корректный JSON, таковым вообще не является, вы путаете его с хэшем. JS абсолютно пофиг, заключать ли свойства в кавычки или нет (кроме случаев с минусами, плюсами, пробелами, другими зарезервированными символами\словами )
mycoding, опечатался? не Х, а Ф.
>mycoding, опечатался? не Х, а Ф.
Да опечатался ))) Исправил
Лолшто? В каком месте здесь корректный JSON?
Судя по Вашему комментарию, JSON для Вас - просто кусок JavaScript'ового кода. Так вот, вынужден Вас разочаровать, но это не так. Более того, JSON не имеет с JS ничего общего, кроме того, что любая JSON строчка представляет собой корректную запись JS объекта. Но не наоборот!
1. Ключи обязательно в двойных кавычках.
2. Значения ключей - строки, объекты, числа, массивы (+ null, false, true). Так как JSON - это формат представления данных, ни о каком вычислительном процессе и речи быть не может. Т.е. утверждение, что {"eval": eval('Lalala')} - корректный JSON - феерический бред.
3. Средства для работы с JSON'ом существуют для многих языков, отсюда логически вытекает предыдущее утверждение про eval. Поэтому и нужен единый стандарт, который является "вырезкой" из JS.
Рекомендую ознакомиться: http://json.org/
Пример с
не является фишкой JS. Что в Си, что в Хаскелле, Пайтоне, Руби или php, 0.1 + 0.2 != 0.3.Таковы особенности реализации чисел с плавающей точкой и каждый программист просто обязан знать об этом.
Последний пример с json был показан для наглядности только в работей jsonp. Он не работает? Такой синтаксис описания объекта появился в javaScript под названием json.
Можно обратить внимание, на то, что написано: такой метод прекрасно будет работать в jsonp. Другое дело мегрируемый json формат. Его имена должны быть в кавычках, а значения не должны быть функциями. Естественно, что это будет работать только в js прямым вызовом, чем и является jsonp. Разве не его рассматривает автор? А теперь скажите, имеет ли смысл в jsonp держать имена свойств в кавычках? Может быть и юникодить всё внутри строк, как предписывает формат? Нет конечно. Из текста видно плохо, так что уточняю еще раз, последний пример относится !ТОЛЬКО к jsonp, всё что написано выше, относится к классическому межплатформенному формату json и описывает примерно то-же, что и на json.org. Про не понимание, что такое json относил, например к этому примеру:
{"success":"true"} - это json,
{"success":true} - не json.
На самом деле оба решения верны, только второй сохраняет свою логическую природу и т.д. Предполоваю фленеган такого не мог написать...
Собственно, а по чему не то, что ожидаем?
Элементу массива 1 - была присвоена функция, которая выводит переменную i, а не ее значение.
После того как цикл завершился i равно 100. Все верно, вполне ожидаемо.
alert(+new Date());
Чето много символов, пишите так
alert(+new Date);
И зачем? Вообще писать нужно так: