이 글은 QR코드 스캔과 파싱을 구현하기 위한 HTML5 관련 정보를 주로 소개하고 있습니다. 필요한 친구들이 참고하면 됩니다.
소개:
최근 웨이보 클라이언트에 요청이 있는 페이지가 있습니다. h5에서 버튼은 기본과 상호 작용하여 카메라를 호출하고 QR 코드를 스캔하고 구문 분석할 수 있습니다. Weibo 클라이언트가 아닌 경우(WeChat 또는 Safari와 같은 기본 브라우저)에서 시스템의 사진 또는 사진 업로드 버튼을 호출하고 사진을 찍거나 사진을 업로드하여 QR 코드를 구문 분석합니다.
두 번째 옵션을 사용하려면 프런트엔드 js에서 QR 코드를 구문 분석해야 합니다. 이는 타사 구문 분석 라이브러리 jsqrcode에 의존합니다. 이 라이브러리는 이미 브라우저 측에서 카메라를 호출하는 작업을 지원하지만 getUserMedia라는 속성에 의존합니다. 모바일 브라우저는 이 속성을 잘 지원하지 않으므로 이미지를 업로드해야만 QR 코드를 간접적으로 구문 분석할 수 있습니다.
getUserMedia 속성 호환 브라우저 목록:
먼저 QR 코드 구문 분석을 위한 훌륭한 코드를 제공하여 많은 작업량을 줄여준 jsqrcode 개발자에게 감사의 말씀을 전하고 싶습니다. jsqrcode 주소: 클릭하세요
내 코드 라이브러리 주소: 클릭하세요
1. 해결된 문제:
1. QR 코드를 스캔하고 분석하기 위해 Weibo 클라이언트를 호출할 수 있습니다. 기본 브라우저 QR 코드를 스캔하고 WeChat 클라이언트에서 구문 분석합니다.
웹 측 또는 h5 측에서 직접 스캔 작업을 완료할 수 있습니다. 3. 분석에 실패하기 쉽고(사진을 찍고 사진을 스캔하려면 렌즈가 QR 코드에 매우 가까워야 함) 기본 통화 카메라 분석에 비해 1~2초 지연이 발생합니다.
지침: 이 플러그인은 zepto.js 또는 jQuery.js와 함께 사용해야 합니다.
사용 방법:
1. 필요한 페이지에서 다음 순서로 lib 디렉터리에 있는 js 파일을 소개합니다.
코드 복사
코드는 다음과 같습니다.<script src="lib/zepto.js"></script>
<script src="lib/qrcode.lib.min.js"></script>
<script src="lib/qrcode.js"></script>
코드 복사
<p class="qr-btn" node-type="jsbridge">扫描二维码1 <input node-type="jsbridge" type="file" name="myPhoto" value="扫描二维码1" /> </p>
코드를 복사하세요
input[node-type=jsbridge]{ visibility: hidden; }
코드를 복사합니다.
//初始化扫描二维码按钮,传入自定义的 node-type 属性 $(function() { Qrcode.init($('[node-type=jsbridge]')); });
코드를 복사합니다.
코드
(function($) { var Qrcode = function(tempBtn) { //该对象只支持微博域下的解析,也就是说不是微博域下的页面只能用第二种方案解析二维码 if (window.WeiboJSBridge) { $(tempBtn).on('click', this.weiBoBridge); } else { $(tempBtn).on('change', this.getImgFile); } }; Qrcode.prototype = { weiBoBridge: function() { WeiboJSBridge.invoke('scanQRCode', null, function(params) { //得到扫码的结果 location.href=params.result; }); }, getImgFile: function() { var _this_ = this; var imgFile = $(this)[0].files; var oFile = imgFile[0]; var oFReader = new FileReader(); var rFilter = /^(?:image\/bmp|image\/cis\-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg\+xml|image\/tiff|image\/x\-cmu\-raster|image\/x\-cmx|image\/x\-icon|image\/x\-portable\-anymap|image\/x\-portable\-bitmap|image\/x\-portable\-graymap|image\/x\-portable\-pixmap|image\/x\-rgb|image\/x\-xbitmap|image\/x\-xpixmap|image\/x\-xwindowdump)$/i; if (imgFile.length === 0) { return; } if (!rFilter.test(oFile.type)) { alert("选择正确的图片格式!"); return; } //读取图片成功后执行的代码 oFReader.onload = function(oFREvent) { qrcode.decode(oFREvent.target.result); qrcode.callback = function(data) { //得到扫码的结果 location.href = data; }; }; oFReader.readAsDataURL(oFile); }, destory: function() { $(tempBtn).off('click'); } }; //初始化 Qrcode.init = function(tempBtn) { var _this_ = this; var inputDom; tempBtn.each(function() { new _this_($(this)); }); $('[node-type=qr-btn]').on('click', function() { $(this).find('[node-type=jsbridge]')[0].click(); }); }; window.Qrcode = Qrcode; })(window.Zepto ? Zepto : jQuery);
샘플 화면 1. 전화하기 전 페이지
2. 전화하기 전 페이지
위 내용은 Html5는 QR 코드 스캐닝 및 구문 분석을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!