首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React Google Recaptcha

React Google Recaptcha
EN

Stack Overflow用户
提问于 2017-09-29 11:19:56
回答 1查看 1.1K关注 0票数 0

使用React Google Recaptcha npm包(https://www.npmjs.com/package/react-google-recaptcha),可以很好地将验证码显示在屏幕上。

我想知道有没有办法让这个验证码不可操作/禁用?我们的目标是只有在某些条件匹配时才启用它。

请分享一些技巧/建议。谢谢!

以下是代码片段:

代码语言:javascript
复制
 import Recaptcha from "react-google-recaptcha";
 <Recaptcha sitekey='#' onChange={enableStuff} />
EN

回答 1

Stack Overflow用户

发布于 2018-06-14 05:57:50

遗憾的是,一旦呈现了reCAPTCHA小部件,就不能禁用与它的交互。

您所能做的就是在某些条件匹配时呈现小部件。例如:

代码语言:javascript
复制
class Example extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      ready: false
    }
  }
  
  onChange = (e) => {
    this.setState({ ready: e.target.checked });
  }
  
  render() {
    return(
      <div>
        <input type="checkbox" onChange={this.onChange} />
        {this.state.ready && 
          <Reaptcha sitekey="YOUR_KEY" onVerify={() => {}} />
        }
      </div>
    )
  }
}

ReactDOM.render(
  <Example />,
  document.getElementById('app')
);
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.4.1/umd/react.development.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.4.1/umd/react-dom.development.js"></script>
<script src="https://cdn.jsdelivr.net/npm/reaptcha@1.1.0-beta.1"></script>

<div id="app"></div>

使用的库是https://github.com/sarneeh/reaptcha

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46481309

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档