Вход

Просмотр полной версии : Передача строкового параметра функции в виде цифр


artur'chik
15.06.2014, 10:45
Здравствуйте, столкнулся с проблемой типов. Много лет пишу на VB.net, C# в этих языках все просто

Function main(srt as string) as string
return "Входной параметр: " & str
end function

main("0123")

//Результат Входной параметр: 0123

написал на JS:

var mystr='0123';

var function main (str) {
alert(str);
}

main(mystr);

//результат 123



Просто катастрофа ...
Как бороться с типами?

рони
15.06.2014, 10:51
:-? var mystr = '0123';
function main (str) {
alert(str);
}
main(mystr);

artur'chik
15.06.2014, 11:48
вот часть кода:

// data[i].ID '0123'

'<input id="' + data[i].Name + '" type="button" onclick="LoadTrackSelectedCar(' + data[i].ID + ')" value="load" />'


var LoadTrackSelectedCar = function (ID) {
$.post('HandlerTrack.ashx?CarID=' + ID + '&BS=451264' + '&BF=0', '', function (response) {
eval(response);
alert(data);
});

};

Вот это не работает ...

Erolast
15.06.2014, 12:00
А что тут должно произойти-то? Я вот вижу формирование строки, которая так и остается там незадействованной и объявление функции без ее вызова.

artur'chik
15.06.2014, 12:11
Эта строка создает кнопку на странице, при нажатии которой происходит запрос данных у сервера, и если входной строковой параметр имеет вид '123456' то все прекрасно работает, а нежели '0123456' то 0 отбрасывается не могу понять как это победить ...

Erolast
15.06.2014, 12:16
Что? Здесь создается строка. Просто создается строка. Создается и тут же удаляется сборщиком мусора, да, ибо никакой переменной не присваивается. Схерали она должна в DOM попасть?

artur'chik
15.06.2014, 12:20
Что? Здесь создается строка. Просто создается строка. Создается и тут же удаляется сборщиком мусора, да, ибо никакой переменной не присваивается. Схерали она должна в DOM попасть?

там представлен участок кода
Создание меток на yandex map


var initcars = function () {
$.post('HandlerCar.ashx', '', function (response) {

eval(response);
for (i in data) {
//alert(Number(data[i].x), Number(data[i].y));
var myGeoObject = new ymaps.GeoObject({
geometry: {
type: "Point",
coordinates: [Number(data[i].x), Number(data[i].y)]
},
// Свойства.
properties: {
// Контент метки.
iconContent: data[i].Name,
hintContent:
'Имя: ' + data[i].Name + '<br />' +
'ID: ' + data[i].ID + '<br/>' +
'Общий пробег: ' + data[i].Path + '<br/>' +
'Скорость движения: ' + data[i].Speed + '<br />' +
'Время события: ' + data[i].LastTime + '<br />' +
'Загрузить трек => ' + '<input id="' + data[i].Name + '" type="button" onclick="LoadTrackSelectedCar("' + data[i].ID + '")" value="<-->" />',
id: data[i].ID
}
}, {
preset: data[i].IconType
});
myMap.geoObjects.add(myGeoObject);
}

initlist();
initmap();

});
};


var LoadTrackSelectedCar = function (ID) {
$.post('HandlerTrack.ashx?CarID=' + ID + '&BS=456285' + '&BF=0', '', function (response) {
eval(response);
alert(data);
});

};



вот подробнее

jsnb
15.06.2014, 12:31
Я так понимаю что проблема в том, что при вызове функции LoadTrackSelectedCar той сгенерированной кнопкой внутри функции в ID теряется 0? Ну так это потому что в результате конкатенации получается:

'" type="button" onclick="LoadTrackSelectedCar(' + data[i].ID + ')" value="load" />' ==
'" type="button" onclick="LoadTrackSelectedCar(' + '0123' + ')" value="load" />' ==
'" type="button" onclick="LoadTrackSelectedCar(0123)" value="load" />'

В результате в функцию передается число 0123, а не строка. Соответственно решение в том, чтобы поставить кавычки в строку:

'" type="button" onclick="LoadTrackSelectedCar(\'' + data[i].ID + '\')" value="load" />'

Aetae
15.06.2014, 12:36
Соответственно решение в том, чтобы поставить кавычки в строку:...а строку, соответственно, в кавычки.:)

Кстати это'<input id="' + data[i].Name + '" type="button" onclick="LoadTrackSelectedCar("' + data[i].ID + '")" value="<-->" />'тоже работать и не должно, тк получается в итоге:<input id="Name" type="button" onclick="LoadTrackSelectedCar("*!*ID")"*/!* value="<-->" />
<input id="Name" type="button" onclick="LoadTrackSelectedCar(" value="<-->" />Выделенный фрагмент отбрасывается как мусор ибо кавычка закрылась.

jsnb
15.06.2014, 12:48
Кстати это'<input id="' + data[i].Name + '" type="button" onclick="LoadTrackSelectedCar("' + data[i].ID + '")" value="<-->" />'тоже работать и не должно, тк получается в итоге:<input id="Name" type="button" onclick="LoadTrackSelectedCar("*!*ID")"*/!* value="<-->" />
<input id="Name" type="button" onclick="LoadTrackSelectedCar(" value="<-->" />Выделенный фрагмент отбрасывается как мусор ибо кавычка закрылась.
Да я еще минут 15 назад заменил на экранированные одинарные)

artur'chik
15.06.2014, 13:25
Спасибо братцы, я пробовал ставить ковычки и одинарные и двойные и
вот так
LoadTrackSelectedCar(''' + data[i].ID + ''')
но все ровно вылетает ошибка.

Вот так
'" type="button" onclick="LoadTrackSelectedCar(\'' + data[i].ID + '\')" value="load" />'

Все заработало. Спасибо огромное

Aetae
15.06.2014, 21:33
Вообще в простых случаях если вам не хватает двух видов кавычек и приходится прибегать к экранированию, то что-то вы делаете явно не так.