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


Posted in Javascript onDecember 12, 2017

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微信扫码登录样式写法

Javascript 相关文章推荐
javascript 使用 NodeList需要注意的问题
Mar 04 Javascript
jQuery实现长文字部分显示代码
May 13 Javascript
js如何判断用户是否是用微信浏览器
Jun 05 Javascript
node.js中的console.dir方法使用说明
Dec 10 Javascript
jquery实现勾选复选框触发事件给input赋值
Feb 01 Javascript
jQuery在页面加载时动态修改图片尺寸的方法
Mar 20 Javascript
原生js获取iframe中dom元素--父子页面相互获取对方dom元素的方法
Aug 05 Javascript
Iscrool下拉刷新功能实现方法(推荐)
Jun 26 Javascript
Nginx 配置多站点vhost 的方法
Jan 07 Javascript
如何封装了一个vue移动端下拉加载下一页数据的组件
Jan 06 Javascript
vue+eslint+vscode配置教程
Aug 09 Javascript
Vue2.0 实现页面缓存和不缓存的方式
Nov 12 Javascript
基于模板引擎Jade的应用(详解)
Dec 12 #Javascript
jquery获取transform里的值实现方法
Dec 12 #jQuery
JS排序算法之希尔排序与快速排序实现方法
Dec 12 #Javascript
将Sublime Text 3 添加到右键中的简单方法
Dec 12 #Javascript
详解vue渲染函数render的使用
Dec 12 #Javascript
谈谈vue中mixin的一点理解
Dec 12 #Javascript
Vue集成Iframe页面的方法示例
Dec 12 #Javascript
You might like
php设计模式 Facade(外观模式)
2011/06/26 PHP
php实现图片添加水印功能
2014/02/13 PHP
php上传文件常见问题总结
2015/02/03 PHP
lnmp安装多版本PHP共存的方法详解
2018/08/02 PHP
js 鼠标移动显示图片的简单实例
2013/12/25 Javascript
jquery显示loading图片直到网页加载完成的方法
2015/06/25 Javascript
js控制TR的显示隐藏
2016/03/04 Javascript
jQuery中弹出iframe内嵌页面元素到父页面并全屏化的实例代码
2016/12/27 Javascript
JavaScript输入分钟、秒倒计时技巧总结(附代码)
2017/08/17 Javascript
基于JavaScript表单脚本(详解)
2017/10/18 Javascript
Vue+Express实现登录注销功能的实例代码
2019/05/05 Javascript
谈谈JavaScript中的垃圾回收机制
2020/09/17 Javascript
用vue设计一个日历表
2020/12/03 Vue.js
Django中实现一个高性能计数器(Counter)实例
2014/07/09 Python
零基础写python爬虫之使用urllib2组件抓取网页内容
2014/11/04 Python
python实现ipsec开权限实例
2014/11/11 Python
利用python微信库itchat实现微信自动回复功能
2017/05/18 Python
Python基于辗转相除法求解最大公约数的方法示例
2018/04/04 Python
如何利用python制作时间戳转换工具详解
2018/09/12 Python
Python实现常见的回文字符串算法
2018/11/14 Python
python实现flappy bird小游戏
2018/12/24 Python
Python面向对象程序设计类变量与成员变量、类方法与成员方法用法分析
2019/04/12 Python
Tensorflow中的图(tf.Graph)和会话(tf.Session)的实现
2020/04/22 Python
如何基于matlab相机标定导出xml文件
2020/11/02 Python
纯css3实现鼠标经过图片显示描述的动画效果
2014/09/01 HTML / CSS
Made in Design意大利:现代家具、名家灯具和装饰
2020/10/27 全球购物
中专毕业生自荐信
2013/11/16 职场文书
行政主管职责范本
2014/03/07 职场文书
会计系毕业生求职信
2014/05/28 职场文书
诉讼授权委托书范本
2014/10/05 职场文书
机关干部作风建设剖析材料
2014/10/23 职场文书
2015年监理个人工作总结
2015/05/23 职场文书
家长通知书家长意见
2015/06/03 职场文书
写给汽车4S店的创业计划书,拿来即用!
2019/08/09 职场文书
Ruby处理YAML和json数据
2022/04/18 Ruby
Vue3实现简易音乐播放器组件
2022/08/14 Vue.js