live () запускается только один раз - PullRequest
0 голосов
/ 14 ноября 2011

У меня есть следующий скрипт, над которым я работал долгое время:

<!doctype html>
<html>
<head>
    <title>Shop List Demo</title> 
    <meta charset="utf-8">
    <meta content="width=device-width, initial-scale=1" name="viewport">
    <link rel="stylesheet" type="text/css" href="js/jquery.mobile-1.0rc1.min.css" />

    <script type="text/javascript" src="js/jquery-1.6.4.min.js"></script>
    <script type="text/javascript">
        $(document).bind("mobileinit", function() {
        $.mobile.defaultPageTransition = 'none';
        $.mobile.page.prototype.options.addBackBtn = true;
        });
    </script>
    <script type="text/javascript" src="js/jquery.mobile-1.0rc1.min.js"></script>

    <script type="text/javascript">
    var dbSize = 5 * 1024 * 1024; // 5MB
    var db = openDatabase("Oscommerce", "1.0", "Oscommerce Database", dbSize);

    var categories={};

    var list_str = '';
        db.transaction(function (tx) {
        tx.executeSql('SELECT c.categories_id, c.categories_image, c.parent_id, cd.categories_name, COUNT(p2c.categories_id) AS total FROM categories c INNER JOIN categories_description cd ON c.categories_id = cd.categories_id LEFT JOIN products_to_categories p2c ON p2c.categories_id = c.categories_id GROUP BY c.categories_id, cd.categories_name ORDER BY c.sort_order, cd.categories_name', [], function (tx, results) {
            list_str += '<ul data-role="listview" data-inset="true" data-theme="d" data-count-theme="a" data-split-theme="a">';
            var len = results.rows.length, i;

            for (i = 0; i < len; i++) {
                var r = results.rows.item(i);
                categories[r.categories_id] = r;
                //console.log(categories);
                //console.log(r.categories_id+'-'+r.parent_id);
            }

            for(key in categories)
            {

                var parent = 0;  
                var value=categories[key];
                catId = value['categories_id'];
                catName = value['categories_name'];
                catImage = value['categories_image'];
                parentId = value['parent_id'];
                total = value['total'];

                if (parentId == parent) 
                {  

                    if (total == 0){    
                        list_str += '<li id="'+ catId +'"><a class="parentlink" parentid="'+ parentId +'" catid="'+ catId +'" catname="'+ catName +'"><h3>' + catName + '</h3><p>' + catImage + '</p><div class="ui-li-count">'+ total +' products</div></a><a class="parentlink" parentid="'+ parentId +'" catid="'+ catId +'" catname="'+ catName +'">somelink</a></li>';
                    }else{
                        list_str += '<li id="'+ catId +'"><a class="productlink" parentid="'+ parentId +'" catid="'+ catId +'" catname="'+ catName +'"><h3>' + catName + '</h3><p>' + catImage + '</p><div class="ui-li-count">'+ total +' products</div></a><a class="parentlink" parentid="'+ parentId +'" catid="'+ catId +'" catname="'+ catName +'">somelink</a></li>';
                    }

                }
            }

            list_str += '</ul>';

            $('#parents').html(list_str).find('ul').listview();


            }); 
    });

    /////////////////////////////////////
    //call subcategories 
    /////////////////////////////////////
    $('.parentlink').live('click', function() {
        var cat_str = '';
        var childcategories={};
        var childId = $(this).attr("catid");
        var parentcatname = $(this).attr("catname");

        db.transaction(function (tx) {

            tx.executeSql('SELECT c.categories_id, c.categories_image, c.parent_id, cd.categories_name, COUNT(p2c.categories_id) AS total FROM categories c INNER JOIN categories_description cd ON c.categories_id = cd.categories_id LEFT JOIN products_to_categories p2c ON p2c.categories_id = c.categories_id WHERE c.parent_id="'+ childId +'" GROUP BY c.categories_id, cd.categories_name ORDER BY c.sort_order, cd.categories_name', [], function (tx, results) {
                //tx.executeSql('SELECT * FROM categories c,categories_description cd WHERE c.parent_id="'+ childId +'" AND c.categories_id = cd.categories_id ORDER BY sort_order, cd.categories_name', [], function (tx, results) {
                cat_str += '<ul data-role="listview" data-inset="true" data-theme="d" data-count-theme="a" data-split-theme="a">';
                var len = results.rows.length, i;

                for (i = 0; i < len; i++) {
                    var r = results.rows.item(i);
                    childcategories[r.categories_id] = r;
                }

                for(key in childcategories)
                {
                    var value=childcategories[key];
                    childId = value['categories_id'];
                    childName = value['categories_name'];
                    childImage = value['categories_image'];
                    parentId = value['parent_id'];
                    childtotal = value['total'];
                    if (childtotal == 0){   

                        cat_str += '<li id="'+ childId +'"><a class="parentlink" parentid="'+ parentId +'" catid="'+ childId +'" catname="'+ childName +'"><h3>' + childName + '</h3><p>' + childImage + '</p><div class="ui-li-count">'+ childtotal +' products</div></a><a class="parentlink" parentid="'+ parentId +'" catid="'+ childId +'" catname="'+ childName +'">somelink</a></li>';
                    }else{
                        cat_str += '<li id="'+ childId +'"><a class="productlink" parentid="'+ parentId +'" catid="'+ childId +'" catname="'+ childName +'"><h3>' + childName + '</h3><p>' + childImage + '</p><div class="ui-li-count">'+ childtotal +' products</div></a><a class="parentlink" parentid="'+ parentId +'" catid="'+ childId +'" catname="'+ childName +'">somelink</a></li>';

                    }

                }
                cat_str += '</ul>';


                var newPage = $('<div data-role="page" data-url="' + parentcatname + '"><div data-role="header"><h1>' + parentcatname + '</h1></div><div data-role="content">'+ cat_str +'<div id="productlist"></div></div></div>');
                newPage.appendTo( $.mobile.pageContainer );
                //append it to the page container
                $.mobile.changePage(newPage);
            }); 


        }); 
    });
    //if a categorie is clicked what contains products
    //load it's containing products list
    //refered from <a class="productlink"....
    $('.productlink').live('click', function() {

        var catid = $(this).attr("catid");
        var catname = $(this).attr("catname");
        var parentid = $(this).attr("parentid");

        var html_str='';

        db.transaction(function (tx) {
            tx.executeSql('select count(*) as total from products_to_categories where categories_id = "'+ catid +'"', [], function (tx, results) {
            total = results.rows.item(0)['total'];

            if (total > 0){

                html_str += '<ul data-role="listview" data-inset="true" data-theme="d">';
                tx.executeSql('SELECT p.products_model, pd.products_name, p.products_quantity, p.products_weight, p.products_image, p.products_id, p.products_price, p.products_tax_class_id, CASE WHEN s.status <> 0 AND s.status IS NOT NULL THEN s.specials_new_products_price ELSE NULL END AS specials_new_products_price,CASE WHEN s.status <> 0 AND s.status IS NOT NULL THEN s.specials_new_products_price ELSE p.products_price END AS final_price FROM products_description pd, products p LEFT JOIN specials s ON p.products_id = s.products_id, products_to_categories p2c WHERE p.products_status = "1" AND p.products_id = p2c.products_id AND pd.products_id = p2c.products_id AND pd.language_id = "1" AND p2c.categories_id = "'+ catid +'"', [], function (tx, results) {

                var len = results.rows.length, i;
                for (i = 0; i < len; i++) {

                    var r = results.rows.item(i);
                    var prodID = r.products_id;
                    var prodName = r.products_name;
                    var prodDes = r.products_description
                    var prodPrice = r.products_price;   

                    html_str += '<li><a class="attributes" productid="'+ prodID +'"><h3>'+ prodName +'</h3></a><div id="prodAttributes_'+ prodID +'"></div></li>';  

                }

                    html_str += '</ul>';

                var newPage = $('<div data-role="page" data-url="productList'+ catid +'"><div data-role="header"><h1>'+ catname +'</h1></div><div data-role="content">'+ html_str +'</div></div');
                newPage.appendTo( $.mobile.pageContainer );
                //append it to the page container
                $.mobile.changePage(newPage);


                });

             }else{

                if (parentid > 0){
                    var newPage = $('<div data-role="page" data-url="productList'+ catid +'"><div data-role="header"><h1>'+ catname +'</h1></div><div data-role="content">no products for this categorie</div></div');
                    newPage.appendTo( $.mobile.pageContainer );
                    //append it to the page container
                    $.mobile.changePage(newPage);
                }
            }
            });
        });
    });

    //if the product list is loaded
    //generate its attributes if it contains them
    //refered from <a class="attributes" 
    $('.attributes').live('click', function(event) {
        var prodID = $(this).attr("productid");
        //alert('you clicked: ' + prodID);

        var productAtt_str = '';

        db.transaction(function (tx) {

            tx.executeSql('select count(*) as total from products_options popt, products_attributes patrib where patrib.products_id="'+ prodID +'" and patrib.options_id = popt.products_options_id and popt.language_id ="1"', [], function (tx, results) {
            total = results.rows.item(0)['total'];

                if (total > 0){
                productAtt_str += '<div><p>Products Otions ('+ total +'):</p></div>'; //WORKS


                tx.executeSql('SELECT popt.products_options_id, popt.products_options_name,pov.products_options_values_id, pov.products_options_values_name, patrib.options_values_price, patrib.price_prefix FROM products_options popt, products_attributes patrib, products_options_values pov WHERE patrib.products_id="'+ prodID +'" AND patrib.options_id = popt.products_options_id AND patrib.options_values_id = pov.products_options_values_id AND popt.language_id = "1" ORDER BY popt.products_options_name;', [], function (tx, results) {

                    var len = results.rows.length, i;
                    var products_options_array={};
                    for (i = 0; i < len; i++) {

                        var r = results.rows.item(i);
                        products_options_array[r.products_options_values_id] = r;

                    }

                      for(key in products_options_array)
                      {

                        var value=products_options_array[key];

                        prodOpId = value['products_options_id'];
                        prodOpName = value['products_options_name'];
                        prodOpValueId = value['products_options_values_id'];
                        prodOpValueName = value['products_options_values_name'];

                           var arr = [
                        {
                        prodOpId: prodOpName,
                        prodOpValueId: prodOpValueName}
                        ];


                        for (var i = 0; i < arr.length; i++) {
                            var r = arr[i];
                            var name = r.prodOpId;
                            var val = r.prodOpValueId;
                            if ($("#prodAttributes_"+prodID+" select").is("[name*=" + name + "]")) {
                                var select = $("#prodAttributes_"+prodID).find("select[name*=" + name + "]");
                                var option = $("<option></option>");
                                option.val(val);
                                option.text(val);
                                select.append(option);
                            } else {
                                var select = $("<select></select>");
                                select.attr("name", name);
                                select.attr("id", name);
                                var option = $("<option></option>");
                                option.val(val);
                                option.text(val);
                                select.append(option);
                                var label = $("<label></label>");
                                label.attr("for", name);
                                label.attr("class", "select");
                                label.text(name);
                                var div = $("<div></div>");
                                div.attr("data-role", "fieldcontain");
                                div.append(label).append(select);   

                                $(div).appendTo("#prodAttributes_"+prodID);
                            }

                        }
                    }


                    }); 

                }

            }); 
        }); 

    }); 
    </script>   
</head>

<body>  

<!-- /1st page start --> 
<div data-role="page">

    <div data-role="header">
        <h1>categorie information</h1>
    </div><!-- /header -->

    <div id="content" data-role="content">
        <div id="parents"></div>
    </div><!-- /content -->

    <div data-role="footer" >
        <div data-role="navbar">
            <ul>
                <li><a href="db.html" data-ajax="false" data-icon="grid" data-iconpos="top">Load database</a></li>
            </ul>
        </div><!-- /navbar -->
    </div><!-- /footer -->

</div>
<!-- /1st page end --> 

</body> 
</html>

Пока у меня есть рабочий пример здесь . ЭТО ТОЛЬКО РАБОТАЕТ С БРАУЗЕРАМИ, КОТОРЫЕ ПОДДЕРЖИВАЮТ webDB , таких как Chrome.

Проблема возникает при просмотре продукта, например: Оборудование → Графические карты → Matrox G200 MMSи нажмите на название продукта.Показывает атрибуты товара.Это отлично работает для первого клика (для всех продуктов, содержащих атрибуты).Однако, если я вернусь назад, либо кнопкой «Назад» скрипта, либо браузером, а затем снова вернусь к продукту, скрипту не удастся снова открыть атрибуты.

Я попытался использовать диалоговое окно;это тоже не сработало.Затем я попытался выполнить это как функцию, которая тоже не сработала.Я предполагаю, что могу придерживаться использования атрибута класса и решить оттуда.

...