gpt4 book ai didi

jquery - 为什么 onclick 函数不能在类上运行?

转载 作者:太空宇宙 更新时间:2023-11-04 02:59:33 25 4
gpt4 key购买 nike

我正在使用 JQuery 和 Node.js 运行 Drupal 7。我希望在 div onclick 事件中发生一个事件。但是,它不适用于类,尽管如果我使用父 div id 则它可以工作。

我遇到问题的行是:

    $(document).ready(function() {

$('.chatNickname').click(function(){
alert("hello");
});

代码片段在 jsfiddle 中工作......不知道问题是什么。完整代码如下:

<script src="http://<?php print $_SERVER['SERVER_ADDR'] ?>:8080/socket.io/socket.io.js"></script>
<script>
(function($){
var myNick = 'me';
var newlyJoined = true;
var socket = io.connect('http://<?php print $_SERVER['SERVER_ADDR'] ?>:8080');

socket.on('connect', function () {
$('#chat').addClass('connected');
});

socket.on('announcement', function (msg) {
$('#lines').append($('<p>').append($('<em>').text(msg)));
});

socket.on('nicknames', function (nicknames) {
$('#nicknames').empty().append($('<span>Online: </span>'));
for (var i in nicknames) {
$('#nicknames').append($('<div class="chatNickname" id="' + nicknames[i] + '">').text(nicknames[i]));
}
});

socket.on('user message', message);
socket.on('reconnect', function () {
$('#lines').remove();
message('System', 'Reconnected to the server');
});

socket.on('reconnecting', function () {
message('System', 'Attempting to re-connect to the server');
});

socket.on('error', function (e) {
message('System', e ? e : 'A unknown error occurred');
});

socket.on('chat log', function(chatlog) {
if (newlyJoined) {
var i = 0;
for (stamp in chatlog) {
if (chatlog[stamp].type == 'user message') {
var ts = tstamp(stamp);
var nick = chatlog[stamp].nick
var msg = chatlog[stamp].msg
message(ts, nick, msg);
i++;
}
}
if (i > 0) {
$('#lines').append($('<hr>')).append($('<small style="text-align:center; display:block; color: #888;">').text('Chat messages posted within the past half hour appear above this line.')).append($('<hr>'));
$('#lines').get(0).scrollTop = 10000000;
}
newlyJoined = false;
}
});

function message (msg_time, from, msg) {
$('#lines').append($('<p>').append($('<small>').text(msg_time)).append($('<b>').text(from), linkify(msg)));
}

function linkify(inputText) {
//URLs starting with http://, https://, or ftp://
var replacePattern1 = /(\b(https?|ftp):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/gim;
var replacedText = inputText.replace(replacePattern1, '<a href="$1" target="_blank">$1</a>');

//URLs starting with www. (without // before it, or it'd re-link the ones done above)
var replacePattern2 = /(^|[^\/])(www\.[\S]+(\b|$))/gim;
var replacedText = replacedText.replace(replacePattern2, '$1<a href="http://$2" target="_blank">$2</a>');

//Change email addresses to mailto:: links
var replacePattern3 = /(\w+@[a-zA-Z_]+?\.[a-zA-Z]{2,6})/gim;
var replacedText = replacedText.replace(replacePattern3, '<a href="mailto:$1">$1</a>');

return replacedText
}

function tstamp(stamp) {
var currentTime = new Date();
if (typeof stamp != 'undefined') {
currentTime.setTime(stamp);
}
var days = new Array('Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat');
var day = currentTime.getDay();
var hours = currentTime.getHours();
var minutes = currentTime.getMinutes();
if (minutes < 10) {
minutes = "0" + minutes;
}
if (hours > 11) {
var ap = 'p';
}
else {
var ap = 'a';
}
if (hours > 12) {
hours = hours - 12;
}
return "["+ days[day] + " " + hours + ":" + minutes + ap + "m] ";
}

$(document).ready(function() {

$('#nicknames .chatNickname').click(function(){
alert("hello");
});

$('input#message').focus(function() {
if ($(this).val() == 'Type your chat messages here...') {
$(this).val('');
}
});

$('input#show-timestamps').click(function() {
if ($(this).is(':checked')) {
$('#messages p small').show();
}
else {
$('#messages p small').hide();
}
})

socket.emit('nickname', '<?php print $username ?>', function (nick) {
if (nick != 'me') {
myNick = nick;
socket.emit('get log');
return $('#chat').addClass('nickname-set');
}
});

$('#send-message').submit(function () {
message(tstamp(), myNick, $('#message').val());
socket.emit('user message', $('#message').val());
clear();
$('#lines').get(0).scrollTop = 10000000;
return false;
});

function clear () {
$('#message').val('').focus();
};

});
})(jQuery);
</script>
<div id="chat">
<div id="messages">
<div id="nicknames">
</div>
<div id="lines">
</div>
</div>
<form id="send-message" autocomplete="off">
<input id="message" type="text" value="Type your chat messages here..." autocomplete="off" />
<button>Send</button>
</form>
</div>
<small><input id="show-timestamps" type="checkbox" checked="checked" /> Show timestamps</small>

最佳答案

您正在使用套接字并在附加点击处理程序后附加元素。这意味着设置原始单击处理程序时该元素不存在。您需要将事件委托(delegate)给更高的元素,如下所示:

$('#nicknames').on('click', '.chatNickname', function(){ 
alert("hello");
});

关于jquery - 为什么 onclick 函数不能在类上运行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11321791/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com