- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
function getProductIds(text, containerId) {
var products = new Array();
var valueFound = false;
var start = 0;
var end = 0;
var itemCount = 0;
var curChar = 0;
var readStart = text.indexOf(containerId);
var triggerChar = ">";
while (valueFound == false) {
if (text.substring(readStart + curChar, readStart + curChar + triggerChar.length) == triggerChar)
valueFound = true;
else
curChar++;
}
start = readStart + curChar + 1;
valueFound = false;
triggerChar = "</div>";
while (valueFound == false) {
if (text.substring(readStart + curChar, readStart + curChar + triggerChar.length) == triggerChar)
valueFound = true;
else
curChar++;
}
end = readStart + curChar;
var itemsHtml = text.substring(start, end).replace(" ", "").replace("\n", "");
curChar = 0;
triggerChar = "ProductId";
while (curChar < itemsHtml.length) {
if (itemsHtml.substring(curChar, curChar + triggerChar.length) == triggerChar)
itemCount++;
curChar++;
}
for (var curItem = 1; curItem <= itemCount; curItem++) {
var product = new Array();
product[0] = getValue(itemsHtml, "LineItem_" + curItem + "_ProductId", "value=\"", "\"", 1);
product[1] = getValue(itemsHtml, "LineItem_" + curItem + "_ProductName", "value=\"", "\"", 1);
product[2] = getValue(itemsHtml, "LineItem_" + curItem + "_Quantity", "value=\"", "\"", 1);
product[3] = getValue(itemsHtml, "LineItem_" + curItem + "_UnitPrice", "value=\"", "\"", 1);
products[curItem - 1] = product;
}
return products;
}
Шедевральный код. Работают с HTML даже не на нативном js, а как с обычной строкой. Правильно, зачем париться - строки знают все :)
PS Код не мой. Однако стоит отметить, что он успешно используется на реальных сайтах :)