在Javascript里,setTimeout和setInterval接收第一个参数是一个字符串或者一个函数,当在一个对象里面用setTimeout延时调用该对象的方法时
复制代码 代码如下:
function obj() {
thisfn = function() {
alert("ok");
consolelog(this);
setTimeout(thisfn, 1000);//直接使用this引用当前对象
}
}
var o = new obj();
ofn();
然后我们发现上面的代码不是想要的结果,原因是setTimeout里面的this是指向window,所以要调用的函数变成 windowfn 为undefined,于是悲剧了。所以问题的关键在于得到当前对象的引用,于是有以下三种方法
复制代码 代码如下:
// 方法一:
function obj() {
thisfn = function() {
alert("ok");
consolelog(this);
setTimeout(thisfnbind(this), 1000);//通过Functionprototypebind 绑定当前对象
}
}
var o = new obj();
ofn();
这样可以得到正确的结果,可惜Functionprototypebind方法是ES5新增的标准,测试了IE系列发现IE6-8都不支持,只有IE9+可以使用。要想兼容就得简单的模拟下bind,看下面的代码
复制代码 代码如下:
// 方法二:
function obj() {
thisfn = function() {
alert("ok");
setTimeout((function(a,b){
return function(){
bcall(a);
}
})(this,thisfn), 1000);//模拟Functionprototypebind
}
}
var o = new obj();
ofn();
首先通过一个自执行匿名函数传当前对象和对象方法进去,也就是里面的参数a和b,再返回一个闭包,通过call方法使this指向正确。下面是比较简洁的方法
复制代码 代码如下:
// 方法三:
function obj() {
thisfn = function() {
var that = this;//保存当前对象this
alert("ok");
setTimeout(function(){
thatfn();
}, 1000);//通过闭包得到当前作用域,好访问保存好的对象that
}
}
var o = new obj();
ofn();
上面第三个方法的两个关键点是 保存当前对象this为别名that 和 通过闭包得到当前作用域,以访问保存好的对象that;当对象方法里面多层嵌套函数或者setTimeout,setInterval等方法丢失this(也就是this不指向当前对象而是window),所以在this指向正确的作用域保存var that = this就变得很实用了
您说具体点,什么情况下获取当前窗口的对象。
如果是在一个activity里获取dialogd出来没有就是if(dialog!=null&&dialogisshowing){//就是当前窗口是dialog界面 dialogthis就是当前窗口对象}
eles{//是当前activity 为窗口对象, activitythis}
bind是一组用于函数绑定的模板。在对某个函数进行绑定时,可以指定部分参数或全部参数,也可以不指定任何参数,还可以调整各个参数间的顺序。对于未指定的参数,可以使用占位符_1、_2、_3来表示。-1表示绑定后的函数的第1个参数,_2表示绑定后的函数的第2个参数,其他依次类推。
bind可以绑定到普通函数、函数对象、类的成员函数和类的成员变量。下面分别进行介绍。
1、普通函数
1 void nine_arguments(int i1,int i2,int i3,int i4,int i5,int i6,int i7,int i8,int i9);
2 int i1=1, i2=2, i3=3, i4=4, i5=5, i6=6, i7=7, i8=8, i9=9;
3 bind(nine_arguments,_9,_2,_1,_6,_3,_8,_4,_5,_7(i1,i2,i3,i4,i5,i6,i7,i8,i9);
4 bind(nine_arguments,i9,i2,i1,i6,i3,i8,_1,_2,_1)(i8,i9);
5 bind(nine_arguments, i9,i2,i1,i6,i3,i8,i4,i5,i7)();
2、函数对象
1 class CStudent
2 {
3 public:
4 void operator() (string strName, int nAge)
5 {
6 cout << strName << " : " << nAge << endl;
7 }
8 };
9 bind(CStudent(), "Mike", _1)(12);
3、类的成员函数
1 struct TAdd
2 {
3 int Add(int x,int y)
4 {
5 return x+y;
6 }
7 };
8 TAdd tAdd;
9 TAdd p = new TAdd();
10 shared_ptr<TAdd> q(p);
11 bind(TAdd::Add, tAdd, 2, 3)();
12 bind(TAdd::Add, p, 2, 3)();
13 bind(TAdd::Add, q, 2, 3)();
4、类的成员变量
1 void Output(const string &name)
2 {
3 cout << name << endl;
4 }
5
6 map<int, string> map1;
7 for_each(map1begin(), map1end(), bind(Output, bind(map<int,
8 string>::value_type::second, _1)));
bind还可以进行嵌套绑定。假设有一个CPerson类,该类有一个获取年龄的接口int GetAge(),现在有一个CPerson对象的vector,需要对其进行排序,则可以如下使用bind:
1 vector<CPerson> vctPerson;
2 sort(vctPersonbegin(), vctPersonend(), bind(less<int>(),
3 bind(CPerson::GetAge, _1), bind(CPerson::GetAge, _2)));
假设有一个整数的vector, 现在想要获取其中大于20但小于30的整数的个数,则有:
1 count_if(vctNumbegin(), vctNumend, bind(logic_and<bool>(),
2 bind(greater<int>(), _1, 20), bind(less<int>(), _1, 30)));
在使用bind时,还有一些需要特别注意的地方,下面逐一进行介绍。
1、对于指定了值的参数,bind返回的函数对象会保存这些值,并且缺省是以传值方式保存的。考虑下面的代码:
1 void inc(int &a) { a++; }
2 int n = 0;
3 bind(inc, n)();
调用bind返回的函数对象后,n仍然等于0。这是由于bind时,传入的是n的拷贝。如果需要传入n的引用,则可以使用ref或cref函数,比如:
1 bind(inc, ref(n))(); // n现在等于1了
2、bind的第一个参数是一个函数对象,不能用占位符来代替。考虑下面的代码:
1 typedef function<void (int)> Func;
2 vector<Func> vctFunc;
3 for_each(vctFuncbegin(), vctFuncend(), bind(_1, 5)); // 编译出错
此时,可以借助apply模板。apply模板的第一个参数是传入的函数对象,后面可以有若干个参数,表示函数对象的参数。比如:
1 apply<void> a; // void是函数对象的返回值类型
2 a(f); // 相当于调用f()
3 a(f, x); // 相当于调用f(x)
4 a(f, x, y); // 相当于调用f(x, y)
使用apply后,我们可以将vctFunc中的元素当作占位符传递过来。参考代码如下:
1 for_each(vctFuncbegin(), vctFuncend(), bind(apply<void>(), _1, 5));
-- 本文来源于创世软件团队博客, 原文地址: >
在给标签绑定事件时在回调事件里有一个event参数,可以通过eventtarget获取当前对象,在处理函数里把当前对象当做参数传递过去。如:
//绑定事件$('list')click(function(event){
var ele=eventtarget;
deal(ele);
});
//处理函数
function deal(obj){
}
只是举一个例子,如果有错误,请指出。
现在没用过vue框架,都不好意思说自己是干前端呢,当然这句话并不是说干前端非得会vue,只是想说明他的火爆程度,现在连小程序都推出了mpvue,你确定你还不赶紧了解了解vue吗,我这篇文章的内容都是些很基础的vue知识,后续会补上
解析 :
- beforecreate :可以在这加个loading事件
- created :在这结束loading,还做一些初始化,实现函数自执行
- mounted : 在这发起后端请求,拿回数据,配合路由钩子做一些事情
- beforeDestory : 你确认删除XX吗? destoryed :当前组件已被删除,清空相关内容
其中key为对象里面的键,value为对象里面的值,其本意就是动态改变原来已经固定的值值,就需要使用vueset(‘想要改变的对象’,’要渲染的键‘,’要渲染的值‘)
解析
遍历后{{parentname}}的已经固定了,这时候点击编辑按钮,改变里面的值,虽然后台数据已经发生了改变,但那时页面渲染的效果并不会发生改变,这时候要想改变页面上的值,就需要使用vueset(‘想要改变的对象’,’要渲染的键‘,’要渲染的值‘),
在空的数组中不能使用push传入数据,所以应当使用vm$set给数组添加
使用v-bind动态给元素绑定
这样可以在遍历的时候给不同的元素动态绑定不同id
在下次dom更新循结束之后延迟回调,在修改数据之后立即使用这个方法,获取更新后的dom
在vue中获取当前点击的元素对象,在点击的方法里 传 入$event,然后在methods方法里面接受传过来的值,具体如 下
这个指令保持在元素上直到关联实例结束编译 /,可隐藏为编译的标签直到实例准备完毕
computer也是一个对象,类似于methods,在里面也可以定义很多方法。计算属性的结果会被缓存,写法如下:
前一兄弟元素必须有v-if 或v-else-if
前一兄弟必须有v-if或v-else-if
vue包含一组观察数组的变异方法,所以它们也会出发视图更新
由于javascript的限制,Vue不能检测一下变动的数组
对于已经创建实例,vue不能动态添加根级别的响应式属性,但是可以使用Vueset( object, key, value )方法嵌套对象添加响应式属性
props可以是数组或对象,用于接收来父组件的数据,或者使用对象作为替代
1axiospost('url', {data} )
axios发送跨域请求
var headers ={
'headers':{
'Content-Type':' application/x-$>
常见的方法是使用children()方法或者fand()方法都是可以获取到某个元素的子元素的,children()
方法返回匹配元素集合中每个元素的子元素,find()方法获得当前元素集合中每个元素的后代,通过选择器、jQuery
对象或元素来筛选。
1、新建一个html文件,命名为testhtml。
2、在testhtml文件内,引入jqueryminjs库文件,成功加载该文件,才能使用jquery中的方法。
3、在testhtml文件内,使用span创建一行文字,并设置其id属性为test,主要用于下面通过该id获得span对象。
4、在testhtml文件内,使用jquery中的$符号通过id(test)获得span标签对象,再使用bind()方法给它绑定click点击事件,当span元素被点击时,执行function()函数。
5、在function函数内,使用$(this)获得当前对象,相当于使用$("#test")获得对象,通过text()方法获得span的内容,使用alert()方法将内容输出来。在浏览器打开testhtml文件,点击span标签,查看实现的效果。
6、在testhtml文件内,使用this创建一个标签,在该标签内写上测试的文字,同时,使用button标签创建一个按钮,给button按钮绑定onclick点击事件,当按钮被点击时,执行getthis()函数。
7、在getthis()函数内,通过$("this")获得this标签对象,使用text()方法获得span的内容,使用alert()方法将内容输出来。在浏览器打开testhtml文件,点击按钮,查看实现的效果。
以上就是关于javascript条件设置a=0时不起效全部的内容,包括:javascript条件设置a=0时不起效、Android如何获取当前窗口的对象判断它是Activity的类对象还是Dialog的类对象、C++ bind函数等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)