>  기사  >  웹 프론트엔드  >  Html5는 QR 코드 스캐닝 및 구문 분석을 구현합니다.

Html5는 QR 코드 스캐닝 및 구문 분석을 구현합니다.

不言
不言원래의
2018-05-07 16:37:2213200검색

이 글은 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>
2. 플러그인에서 d00a96978081f32deed84c268f52843c, html 구조에는 웹 페이지 스타일에 고정된 표시가 있습니다. 버튼 스타일을 사용자 정의하기 위해 다음 샘플 코드 구조에 따라 코드를 중첩할 수 있습니다

코드 복사

코드는 다음과 같습니다.

<p class="qr-btn" node-type="jsbridge">扫描二维码1 
<input node-type="jsbridge" type="file" name="myPhoto" value="扫描二维码1" /> 
</p>
그런 다음 입력 버튼의 CSS를 설정하여 제가 사용하는 것과 같이 버튼을 숨깁니다. 속성 선택기입니다

코드를 복사하세요


코드는 다음과 같습니다.

input[node-type=jsbridge]{ 
visibility: hidden; 
}
여기서는 필요에 따라 class="qr-btn" 스타일만 정의하면 됩니다. 3. 페이지에서 Qrcode 개체를 초기화합니다.


코드를 복사합니다.

코드는 다음과 같습니다.

//初始化扫描二维码按钮,传入自定义的 node-type 属性 
$(function() { 
Qrcode.init($(&#39;[node-type=jsbridge]&#39;)); 
});
기본 코드 분석

코드를 복사합니다.

코드

(function($) { 
var Qrcode = function(tempBtn) { 
//该对象只支持微博域下的解析,也就是说不是微博域下的页面只能用第二种方案解析二维码 
if (window.WeiboJSBridge) { 
$(tempBtn).on(&#39;click&#39;, this.weiBoBridge); 
} else { 
$(tempBtn).on(&#39;change&#39;, this.getImgFile); 
} 
}; 
Qrcode.prototype = { 
weiBoBridge: function() { 
WeiboJSBridge.invoke(&#39;scanQRCode&#39;, 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(&#39;click&#39;); 
} 
}; 
//初始化 
Qrcode.init = function(tempBtn) { 
var _this_ = this; 
var inputDom; 
tempBtn.each(function() { 
new _this_($(this)); 
}); 
$(&#39;[node-type=qr-btn]&#39;).on(&#39;click&#39;, function() { 
$(this).find(&#39;[node-type=jsbridge]&#39;)[0].click(); 
}); 
}; 
window.Qrcode = Qrcode; 
})(window.Zepto ? Zepto : jQuery);

샘플 화면 1. 전화하기 전 페이지


2. 전화하기 전 페이지

위 내용은 Html5는 QR 코드 스캐닝 및 구문 분석을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.