- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
作为序言,我希望能够获得有关如何完成此类事情的最佳实践的问题的一般答案,以及对我的具体问题的可能答案?
我一直在开发一个“证明你是人类”插件,并且当一切加载时我都会让它工作。我使用 jQuery UI 作为它的 Backbone ,并使用 Draggable 和 Droppable。一般问题是:如何销毁和重置事件中的插件?更具体的问题是:当我将错误的对象拖到该位置时,如何在所有内容都被破坏后重置拖放功能。
下面是伪代码:
(function($){
$.fn.robotProof = function(options){
var defaults = {
//Default variables
}
var options = $.extend(defaults, options);
return this.each(function(defaults){
/* Here I style the elements because they were not styled by a CSS
Then I randomly assign the elements a spot and append them to the container
Then I use Draggable and Droppable */
$('.peg').draggable({
drag: function() {
/* Drag Function Here */
},
revert: 'invalid'
});
$('.hole').droppable ({
accept: '.valid',
drop: function(){
var username = $('#username').val();
var email = $('#email').val();
var password = $('#password').val();
if(!username || !email || !password){ //IF ONE OF THE INPUTS IS EMPTY
$('.hardError').html("You've forgotten something").slideDown(300);
//////* THIS IS WHERE I NEED TO DESTROY/RESET THIS PLUGIN *//////////
} else {
$('.valid').animate({left: "286px",top: "1px"});//success
}
}
});
};
})(jQuery);
$(document).ready(function(){
$('.robotProof').robotProof();
});
您可以在可删除代码中看到错误(最终将出现在所有错误上)我需要能够重置插件。
我觉得(并且已经考虑过这个想法)几乎整个代码都需要是一个函数,这样我就可以再次调用该函数。当我尝试这样做时,我必须嵌套代码,因为它不允许元素再次可拖动,除非我将这些元素也放入函数中,然后函数将调用它自己的函数,我们都知道它不会不要那样工作。
我之前写过几个成功的插件,但这是我在每个插件中都遇到过的问题。我如何销毁所有实例,然后重置插件而不刷新页面。
最佳答案
玩得开心。 :) 看起来我有很多时间,但这正是你想要的。所以线索是用 覆盖你的 jQuery 函数
$.fn.robotProof={}
您会看到它也可以重新启动并重新开始,并具有完整的不同功能内容
<script type="text/javascript">
var i=0;
(function($){
$.fn.SelfDestroy=function(blabla){
function init(){
var brutal = 'mega conspirative content of your plugin :)';
$('#report').text(brutal);
};
init();
return this.each(function(){
$('#counter').text('ding dong'+i).show().fadeOut(200);
i++;
$(this).text(blabla);
});
};
$.fn.Destroy=function(){
// lets overwrite the jQuery plugin function
$.fn.SelfDestroy={};
};
$.fn.Rebuild=function(){
// here we load other work in the same namespace as before
$.fn.SelfDestroy=function(ZoroZonk){
if (ZoroZonk=='push to test if stil running')
$('#report').text('my name is bond, james bond').show().fadeOut(100).fadeIn(100);
};
};
})(jQuery);
$(document).ready(function(){
$('#bomb').on('click',function(){
$().Destroy();
$().Rebuild();
});
$('#report').SelfDestroy('huaaa! time to run! but stil original function work');
});
</script>
<button id="selfdestroytester" onclick="$(this).SelfDestroy('push to test if stil running')">check if valid running code</button>
<div id="report"> placeholder for output </div>
<button id="bomb" onclick="">push to start selfdestroy!</button>
<div id="counter" style="display:none"> hitcounter </div>
关于jQuery:如何销毁或重置插件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15937135/
当你有一个对象 OBJ1 包含一个关键部分 CS 和一个指向另一个对象 OBJ2 的指针时,我无法弄清楚什么是正确的关闭过程 假设您有两个函数 A 和 B。 A进入临界区,修改OBJ2中的数据后离开临
我有一个成员变量声明为 CComPtr m_spXMLDoc; XML 文档是这样创建的 CoCreateInstance(CLSID_DOMDocument, NULL, CLSCTX_INPROC
在我的工作平台中,我遇到了 session_destroy 问题 function logout() { $_SESSION['id'] = ''; session_destroy(); } 在这
如何使用 destroy 删除 jScrollPane。请您给出以下代码的简单示例: $(document).ready(function() { $(".div1").jScrollPane
这是我在这里发表的第一篇文章,但我想对社区表示感谢,因为通过来到这里并在已经得到解答的问题中找到解决方案,我已经无数次找到了问题的解决方案。 话虽这么说,我想进入正题。我正在 Code Gear 的
我在导航 View 中工作。在此导航 View 中,您可以偶然发现个人资料页面。在此个人资料页面中,您可以看到与当前个人资料相关的其他个人资料(基本上是数据 View 中显示的图片)。您可以通过点击这
我想销毁项目中的 session ,这样当我单击“注销”时,它会转到页面“KillSession.jsp”,在该文件中我编写了“session.invalidate();”然后我将用户重定向到登录页面
我有关于 Thread 的 2 问题,我只是想澄清一些事情。使用以下代码: public class MyThread implements Runnable { Boolean StopTh
我遇到了内存泄漏,代码类似于下面的代码(这是每个循环都有不同输入的模拟)。 问题 对象 Object_XXX 非常复杂,它与数据库以及其他填充了数据库数据的对象有连接。 for(int i=0
当我在 Python 中启动一个类时,我给它一些值。然后我调用类中执行某些操作的方法。这是一个片段: class TestClass(): def __init__(self):
我想删除所有 div、类、属性和几乎所有 CKEDITOR 添加到 DOM 的内容。例如调用 jquery tabs("destroy");将删除所有由 jQuery 选项卡添加的 div。我怎样才能
我想清除析构函数中的一个映射,但我不知道它是否为空。如果我按如下方式清除它可以吗? for(std::map::iterator it = m_map.begin(); it != m_map.end
我正在尝试克隆 TikTok 应用。对于主屏幕,我制作了一个 VerticalViewPager(自定义 View 分页器),其中包含“点赞”按钮、标题和评论。我正在从 Firebase 检索视频。
我正在制作自己的游戏。目标之一是在世界中拥有尽可能多的物体。在这个游戏中,需要在一些不可预测的时间段内创建许多对象(比如武器开火会创建一个对象),一旦该弹丸击中某物,该对象也需要被摧毁(也许它击中的东
有没有办法在 JavaScript 中破坏 HTML5 WebWorker? 这是我的情况:我有一个 Web 应用程序生成相当数量的 WebWorker(在 16 到 32 之间的任何地方)来优化一些
如何销毁 php 中的 session ? 事情是当用户点击注销按钮时, session 将结束,他将被重定向到 index.php 这是我的代码 客户.php 这是来自用户想要再次登录的 ind
关于 GtkBuilder 的问题。 当我们取消引用构建器指针时,它是否会破坏构建器创建的所有屏幕/小部件? if( builder_ptr ) g_object_unref(G_OBJECT
有没有办法销毁 WebView 实例?如果页面加载,并说视频开始播放,我希望能够,当我隐藏 WebView 时,基本上可以销毁它,或者至少重置它。 我知道我可以听 visibleProperty 并执
我有一组可拖动的元素。如何删除可拖动功能? $('.draggable').draggable('disable') 在我的情况下不是一个选项 $('.draggable').draggable('d
下面的代码会抛出一个 EZDecompressionError 消息 'Invalid ZStream operation' 每当行 Reader.Free 被执行。有人可以告诉我这段代码有什么问题吗
我是一名优秀的程序员,十分优秀!