欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

自定义PC微信扫码登录样式写法

程序员文章站 2022-05-03 09:06:52
pc微信扫码登录 近期做一个pc端微信扫码登录的需求,微信扫码有两种方式,一种是新开一个二维码页面,另一种是内嵌入产品网页。本次以内嵌二维码为例,具体怎样在页面中显示一个...

pc微信扫码登录

近期做一个pc端微信扫码登录的需求,微信扫码有两种方式,一种是新开一个二维码页面,另一种是内嵌入产品网页。本次以内嵌二维码为例,具体怎样在页面中显示一个登陆二维码,文档说的很清楚,就不赘述了,文档地址:https://open.weixin.qq.com/cg...

解决自定义微信二维码样式问题

当一切准备妥当之后,网页上的二维码初始默认是这个样子。

自定义PC微信扫码登录样式写法

特别大不说(默认二维码大小280x280),还有微信登录的title,下方也有扫码登录的提示。
幸运的是,微信留了一个api给我们自定义样式的机会,在之前实例化一个二维码的时候,实例对象中href属性,允许设置样式。

var obj = new wxlogin({
      id:"login_container", 
      appid: "", 
      scope: "", 
      redirect_uri: "",
      state: "",
      style: "",
      href: "../qrcode.css"//就是这个属性
      });

不幸的是,在href中传入样式文件的地址,会报错。貌似微信为了安全考虑,只允许访问https的资源。于是现在采用第二种解决办法data-url。

通过访问data-url解决样式问题

写一个nodejs,脚本将刚才的css资源转换为data-url。具体代码实现为:

var fs = require('fs');
// function to encode file data to base64 encoded string
function base64_encode(file) {
 // read binary data
 var bitmap = fs.readfilesync(file);
 // convert binary data to base64 encoded string
 return 'data:text/css;base64,'+new buffer(bitmap).tostring('base64');
}
console.log(base64_encode('./qrcode.css'))

运行node脚本,复制打印出来的data-url,然后赋值给刚才的href。

自定义PC微信扫码登录样式写法

var obj = new wxlogin({
      id:"login_container", 
      appid: "", 
      scope: "", 
      redirect_uri: "",
      state: "",
      style: "",
           href:"data:text/css;base64,lmltcg93zxjcb3gglnfyy29kzsb7d2lkdgg6idiwmhb4o30nci5pbxbvd2vyqm94ic50axrszsb7zglzcgxhetogbm9uztt9dqouaw1wb3dlckjvecauaw5mbyb7d2lkdgg6idiwmhb4o30nci5zdgf0dxnfawnvbib7zglzcgxhetpub25lf
q0klmltcg93zxjcb3gglnn0yxr1cyb7dgv4dc1hbglnbjogy2vudgvyo30="//data-url
      });

注意这里的mime类型,一定要返回text/css。

自定义二维码:


自定义PC微信扫码登录样式写法