HTML中的多个onload错误

时间:2013-05-24 04:59:26

标签: javascript html

HTML: -

在body标签中我使用了onload="variable2.init() ; variable1.init();"

JavaScript的: -

var variable1 = {
rssUrl: 'http://feeds.feedburner.com/football-italia/pAjS',

init: function() {
    this.getRSS();
},

getRSS: function() {
    jQuery.getFeed({
        url: variable1.rssUrl,
        success: function showFeed(feed) {
            variable1.parseRSS(feed);
        }
    });
},

parseRSS: function(feed) {
    var main = '';
    var posts = '';
    var className = 'even';
    var pst = {};
    for (i = 0; i < feed.items.length; i++) {
        pst = variable1.parsefootballitaliaRSS(feed.items[i]);
        if (className == 'odd') {
            className = 'even';
        }
        else {
            className = 'odd';
        }
        var shorter = pst.story.replace(/<(?:.|\n)*?>/gm, '');
        item_date = new Date(feed.items[i].updated);
        main += '<div id="content1" class="post-main ' + className + '" onclick="mwl.setGroupTarget(\'#screens1\', \'#blog_posts1\', \'ui-show\', \'ui-hide\');mwl.setGroupTarget(\'#blog_posts1\', \'#post' + (i+1) + '\', \'ui-show\', \'ui-hide\');">';
        main += '<b>' + pst.title.trunc(55, true) + '</b><br />' + shorter.trunc(30, true);
        main += '<div class="datetime">' + item_date.getDateTime() + '</div></div>';

        posts += '<div class="post-wrapper ui-hide" id="post' + (i+1) + '">';
        posts += '<div class="post-title"><b>' + pst.title + '</b></div>';
        posts += feed.items[i].description;
        posts += '</div>';
    }

    jQuery('#main_screen1').html(main);
    jQuery('#blog_posts1').html(posts);

},

parsefootballitaliaRSS: function(item) {
    var match = item.description.match('src="([^"]+)"');
    var part = item.description.split('<font size="-1">');
    var arr = {
        title: item.title,
        link: item.link,
        image: match,
        site_title: item.title,
        story: item.description
    };

    return arr;
}
};

var variable2 = {
    weatherRSS: 'http://feeds.feedburner.com/go/ELkW',

    init: function() {
        this.getWeatherRSS();
    },

    getWeatherRSS: function() {
        jQuery.getFeed({
            url: variable2.weatherRSS,
            success: function showFeed(feed) {
                variable2.parseWeather(feed);
            }
        });
    },

    parseWeather: function(feed) {
        var main = '';
        var posts = '';
        var className = 'even';
        var pst = {};
        for (i = 0; i < feed.items.length; i++) {
            pst = variable2.parsegoRSS(feed.items[i]);
            if (className == 'odd') {
                className = 'even';
            }
            else {
                className = 'odd';
            }
            var shorter = pst.story.replace(/<(?:.|\n)*?>/gm, '');
            item_date = new Date(feed.items[i].updated);
            main += '<div id="content2" class="post-main ' + className + '" onclick="mwl.setGroupTarget(\'#screens2\', \'#blog_posts2\', \'ui-show\', \'ui-hide\');mwl.setGroupTarget(\'#blog_posts2\', \'#post' + (i+1) + '\', \'ui-show\', \'ui-hide\');">';
            main += '<b>' + pst.title.trunc(55, true) + '</b><br />' + shorter.trunc(30, true);
            main += '<div class="datetime">' + item_date.getDateTime() + '</div></div>';

            posts += '<div class="post-wrapper ui-hide" id="post' + (i+1) + '">';
            posts += '<div class="post-title"><b>' + pst.title + '</b></div>';
            posts += feed.items[i].description;
            posts += '</div>';
        }

        jQuery('#main_screen2').html(main);
        jQuery('#blog_posts2').html(posts);

    },

    parsegoRSS: function(item) {
        var match = item.description.match('src="([^"]+)"');
        var part = item.description.split('<font size="-1">');
        var arr = {
            title: item.title,
            link: item.link,
            image: match,
            site_title: item.title,
            story: item.description
        };

        return arr;
    }
};

当我运行程序时,它只读取其中一个变量,即1或2 如何纠正它们以读取两个变量?

2 个答案:

答案 0 :(得分:0)

试试这个

<body onload="callFunctions()">

<强> JS -

function callFunctions()
{
variable1.init(); 
variable2.init();
}

更新 -

另外 there are other different ways to call multiple functions on page load

希望它能帮助你。

答案 1 :(得分:0)

使用此功能。

<script type="text/javascript">
 window.onload = function() {  

  variable1.init(); 
  variable2.init();

 }
</script>