使用jquery组件qrcode生成二维码及应用指南

2020-05-23 06:00:22易采站长站整理

        } else {   
            out += String.fromCharCode(0xC0 | ((c >>  6) & 0x1F));   
            out += String.fromCharCode(0x80 | ((c >>  0) & 0x3F));   
        }   
    }   
    return out;   
}

下载二维码

用前端画出来的二维码,不是一个canvas就是一个table,如何下载呢?我们只需要将canvas的内容画到image上,下载下来即可。


function download(canvasElem, filename, imageType) {
    var event, saveLink, imageData, defalutImageType;
    defalutImageType = ‘png’;//定义默认图片类型
    imageData = canvasElem.toDataURL(imageType || defalutImageType);//将canvas元素转化为image data
    saveLink = document.createElementNS(‘http://www.w3.org/1999/xhtml’, ‘a’);
    saveLink.href = imageData;
    saveLink.download = filename;
    event = document.createEvent(‘MouseEvents’);
    event.initMouseEvent(‘click’, true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
    saveLink.dispatchEvent(event);
};

在angular中的简单封装

在angular中使用,可以封装成directive。不过要确保已经引入了之前的两个js文件。


var appModule = angular.module(‘app’, []);
appModule.directive(‘qrcode’, function() {
    return {
        restrict: “A”,
        scope: {
          text    : ‘=’,
          options : ‘=’
        },
        link: function(scope, elem, attrs) {
          var $elem, options;
          $elem = $(elem);
          options = { //获取元素的宽度和高度
            width: $elem.width(),
            height: $elem.height()
          };
          angular.extend(options, scope.options);
          scope.$watch(‘text’, function(newText) {