我正在做一个使用jQuery的打字效果,并发现这个代码,并编辑它完美的工作,因为我需要。如何在第一次迭代后停止此电传动画?
但是,我有一个问题,我无法停止循环。
我试图检测到最后一段被打印出来,所以我可以在没有运气的情况下添加一个函数。
您的建议和提示表示赞赏。
的代码是:
(function ($) {
function typeString($target, str, cursor, delay, cb) {
$target.html(function (_, html) {
return html + str[cursor];
});
if (cursor < str.length - 1) {
setTimeout(function() {
typeString($target, str, cursor + 1, delay, cb);
}, delay);
}
else {
cb();
}
}
function deleteString($target, delay, cb) {
var length;
$target.html(function (_, html) {
length = html.length;
return html.substr(0, length - 1);
});
if (length > 1) {
setTimeout(function() {
deleteString($target, delay, cb);
}, delay);
}
else {
cb();
}
}
// jQuery hook
$.fn.extend({
teletype: function (opts) {
var settings = $.extend({}, $.teletype.defaults, opts);
return $(this).each(function() {
(function loop($tar, idx) {
// type
typeString($tar, settings.text[idx], 0, settings.delay, function() {
// delete
setTimeout(function() {
deleteString($tar, settings.delay, function() {
loop($tar, (idx + 1) % settings.text.length);
});
}, settings.pause);
});
}($(this), 0));
});
}
});
// plugin defaults
$.extend({
teletype: {
defaults: {
delay: 100,
pause: 5000,
text: []
}
}
});
}(jQuery));
$('#target').teletype({
text: [
'Lorem ipsum dolor sit amet, consetetur sadipscing elitr,',
'sed diam nonumy eirmod tempor invidunt ut labore et dolore',
'magna aliquyam erat, sed diam voluptua. At vero eos et'
]
});
$('#cursor').teletype({
text: ['_', ' '],
delay: 0,
pause: 500
});
你可以提醒打印不循环的最后一条消息之后的文字?随时编辑我的代码,因为我是jquery的新手 – Sinan 2013-02-13 19:22:03