我正在使用基于jQuery的WordPress Twitter小部件并收到错误“ReferenceError: _ is not defined
”。
我不确定如何声明变量“_”。
这是小部件:
<script type="text/javascript">
<!--//--><![CDATA[//><!--
function twitterCallback2(twitters) {
var statusHTML = [];
for (var i=0; i<twitters.length; i++){
var username = twitters[i].user.screen_name;
var status = twitters[i].text.replace(/((https?|s?ftp|ssh)\:\/\/[^"\s\<\>]*[^.,;'">\:\s\<\>\)\]\!])/g, function(url) {
return '<a href="'+url+'">'+url+'</a>';
}).replace(/\B@([_a-z0-9]+)/ig, function(reply) {
return reply.charAt(0)+'<a href="http://twitter.com/'+reply.substring(1)+'">'+reply.substring(1)+'</a>';
});
statusHTML.push( '\
<li class="tweet">\
<span class="content">'+status+'\
<a style="font-size:85%" class="time" href="http://twitter.com/'+username+'/statuses/'+twitters[i].id_str+'">('+relative_time(twitters[i].created_at)+')</a></span>\
<div class="clearfix"></div></li>' );
}
document.getElementById('twitter_update_list_<?php echo $unique_id; ?>').innerHTML = statusHTML.join('');
var template = '\
<span class="author">\
<img src="<%= user.profile_image_url %>"> \
<a class="username" href="http://twitter.com/<%= user.screen_name %>">\
<strong><%= user.screen_name %></strong>\
</a>\
</span>';
jQuery( _.template( template, { user: twitters[0].user } )).insertAfter('.bizsteam_twitter ul');
}
function relative_time(time_value) {
var values = time_value.split( " " );
time_value = values[1] + " " + values[2] + ", " + values[5] + " " + values[3];
var parsed_date = Date.parse(time_value);
var relative_to = (arguments.length > 1) ? arguments[1] : new Date();
var delta = parseInt((relative_to.getTime() - parsed_date) / 1000);
delta = delta + (relative_to.getTimezoneOffset() * 60);
if (delta < 60) {
return 'less than a minute ago';
} else if(delta < 120) {
return 'about a minute ago';
} else if(delta < (60*60)) {
return (parseInt(delta / 60)).toString() + ' minutes ago';
} else if(delta < (120*60)) {
return 'about an hour ago';
} else if(delta < (24*60*60)) {
return 'about ' + (parseInt(delta / 3600)).toString() + ' hours ago';
} else if(delta < (48*60*60)) {
return '1 day ago';
} else {
return (parseInt(delta / 86400)).toString() + ' days ago';
}
}
//-->!]]>
</script>
<?php
if($exclude_replies != ''){ $exclude_replies_str = '&exclude_replies='.$exclude_replies; } else { $exclude_replies_str = ''; }
?>
<script type="text/javascript" src="http://api.twitter.com/1/statuses/user_timeline/<?php echo $twitter_username; ?>.json?callback=twitterCallback2&count=<?php echo $twitter_count; ?>&include_rts=t<?php echo $exclude_replies_str; ?>"></script>
Firebug声明带有错误的代码行是:
jQuery( _.template( template, { user: twitters[0].user } )).insertAfter('.bizsteam_twitter ul');
非常感谢任何帮助
答案 0 :(得分:59)
您的小部件将Underscore.js / LoDash.js作为依赖项。
您可以在此处获取:underscore,lodash
尝试将其添加到您的代码中,以便查看是否有效:
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/lodash.js/0.10.0/lodash.min.js"></script>
答案 1 :(得分:1)
我在网站的wp-admin部分遇到了同样的问题。我列出了下划线脚本cdn,它修复了问题。
function kk_admin_scripts() {
wp_enqueue_script('underscore', '//cdnjs.cloudflare.com/ajax/libs/lodash.js/0.10.0/lodash.min.js' );
}
add_action( 'admin_enqueue_scripts', 'kk_admin_scripts' );
答案 2 :(得分:0)
您可以通过凉亭安装它:
Node.js npm install underscore
Meteor.js meteor add underscore
Require.js require(["underscore"], ...
Bower bower install underscore
Component component install jashkenas/underscore
这是指向官方网页http://underscorejs.org/
的链接