taro & querySelector & refs
taro & querySelector & refs
delayQuerySelector
https://github.com/NervJS/taro-ui/blob/dev/src/common/utils.ts#L18
function delayQuerySelector(
  self,
  selectorStr: string,
  delayTime = 500
): Promise<Array<execObject>> {
  const $scope = ENV === Taro.ENV_TYPE.WEB ? self : self.$scope
  const selector: SelectorQuery = Taro.createSelectorQuery().in($scope)
  return new Promise(resolve => {
    delay(delayTime).then(() => {
      selector
        .select(selectorStr)
        .boundingClientRect()
        .exec((res: Array<execObject>) => {
          resolve(res)
        })
    })
  })
}
refs
https://nervjs.github.io/taro/docs/ref.html
https://nervjs.github.io/taro/docs/ref.html#通过函数创建-ref
函数创建 ref
// 不管在任何情况下,Taro 都推荐你使用函数的方式创建 ref
// 自定义组件, 父组件
class MyComponent extends Component {
  roar () {
    // 会打印 `miao, miao, miao~`
    this.cat.miao()
  }
  refCat = (node) => this.cat = node // `this.cat` 会变成 `Cat` 组件实例的引用
  render () {
    return <Cat ref={this.refCat} />
  }
}
// 子组件
class Cat extends Component {
  miao () {
    console.log('miao, miao, miao~')
  }
  render () {
    return <View />
  }
}
Taro.createRef
// 自定义组件, 父组件
class MyComponent extends Component {
  this.cat = Taro.createRef()
  roar () {
    // 会打印 `miao, miao, miao~`
    this.cat.current.miao()
  }
  render () {
    return <Cat ref={this.cat} />
  }
}
// 子组件
class Cat extends Component {
  miao () {
    console.log('miao, miao, miao~')
  }
  render () {
    return <View />
  }
}

bug
https://github.com/NervJS/taro/issues/4832
https://github.com/NervJS/taro/issues/4851
https://github.com/NervJS/taro/issues/610
taro & querySelector & refs的更多相关文章
- Taro 3.x in Action
		
Taro 3.x in Action React, 小程序 https://taro-docs.jd.com/taro/docs/README Taro Next 跨端, 跨框架 Taro 是一个开放 ...
 - taro refs引用
		
创建 Refs Taro 支持使用字符串和函数两种方式创建 Ref: 使用字符串创建 ref 通过函数创建 ref(推荐) 你也可以通过传递一个函数创建 ref, 在函数中被引用的组件会作为函数的第一 ...
 - Taro Next H5 跨框架组件库实践
		
作者:凹凸曼 - JJ Taro 是一款多端开发框架.开发者只需编写一份代码,即可生成各小程序端.H5 以及 React Native 的应用. Taro Next 近期已发布 beta 版本,全面完 ...
 - $refs的用法及作用
		
获取DOM元素,一般用document.querySelector获取这个dom节点,然后在获取input的值 但是用ref绑定之后,就不需要在获取dom节点了,直接在上面的input上绑定input ...
 - Vue.js中ref ($refs)用法举例总结
		
原文地址:http://www.cnblogs.com/xueweijie/p/6907676.html <div id="app"> <input type=& ...
 - vue $refs的基本用法
		
<div id="app"> <input type="text" ref="input1"/> <butto ...
 - vue & button & refs & click & bug
		
vue & button & refs & click & bug $refs.btn.click() ??? vue & refs $refs.btn.$em ...
 - Taro自定义Modal对话框组件|taro仿微信、android弹窗
		
基于Taro多端实践TaroPop:自定义模态框|dialog对话框|msg消息框|Toast提示 taro自定义弹出框支持编译到多端H5/小程序/ReactNative,还可以自定义弹窗类型/弹窗样 ...
 - vue中$refs的用法及作用详解
		
一般来讲,获取DOM元素,需要使用document.querySelector('#input1')方法去获取dom节点,然后再获取input1的值. 但是使用了ref绑定之后,我们就不需要再获取do ...
 
随机推荐
- (Sql Server)SQL FOR XML PATH
			
FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作.那么以一个实例为主 ...
 - Makefile 描述的是文件编译的相关规则,它的规则主要是两个部分组成,分别是依赖的关系和执行的命令 PHONY伪目标实践
			
Makefile的工作流程 http://c.biancheng.net/view/7091.html Makefile文件是什么? 我们教程主要是讲的是 Makefile .很多 Linux(Uni ...
 - 【LinuxShell】free 命令详解
			
前言 free命令用来显示Linux中的内存使用信息,包括空闲的.已用的物理内存,swap内存,及被内核使用的buffer.在Linux系统监控的工具中,free命令是最经常使用的命令之一. 命令格式 ...
 - C++ Primer Plus读书笔记(八)函数探幽
			
1.内联函数 inline int square(x) {return x*x} 2.引用变量 int& 中的& 不是地址运算符,就想定义指针时的char* 一样,int&指的 ...
 - Python爬虫学习笔记(三)
			
Cookies: 以抓取https://www.yaozh.com/为例 Test1(不使用cookies): 代码: import urllib.request # 1.添加URL url = &q ...
 - mysql、sql server、oracle大比较
			
MYSQL 多个数据库多个用户形式(最好每个数据库对应一个用户),占用内存小,适用于所有平台,开源免费 客户端和命令窗口,都是由数据库决定内容-> use datebase; 组函数在selec ...
 - Centos7服务器安装Docker及Docker镜像加速,Docker删除
			
Centos7服务器安装Docker及Docker镜像加速,Docker删除 1.Centos7服务器安装Docker 1.1 root账户登录,查看内核版本如下 1.1.1 卸载服务器旧版本Dock ...
 - Spring3文件上传,提速你的Web开发
			
Spring1 推出的时候可以说是不小的颠覆了J2EE 的开发,彻底把EJB打败,将J2EE开发进行简化,Spring2 推出以后完美的与多种开源框架与服务器的结合,让你对其拥抱的更紧,Spring变 ...
 - DedeCMS程序使用拼音首字母做栏目名称的方法
			
Dedecms织梦程序默认使用拼音为保存目录的时候使用的是中文全拼,当遇到栏目名称比较长的时候目录名称看起来有点冗长,这时候大多数站长喜欢使用拼音首字母作为栏目的保存目录,那么就需要修改 dede/c ...
 - C++的匿名函数(lambda表达式)
			
总述 C++11提供了对匿名函数的支持,称为Lambda函数(也叫Lambda表达式). 它是定义和使用匿名函数对象的一种简便的方式.匿名函数是我们需要用到的一个函数,但是又不想去费力命名一个函数的 ...