前端代码收集

2018-12-05  本文已影响0人  大房子里的小乌龟
//禁用微信右上角分享功能js代码
function onBridgeReady() {
  WeixinJSBridge.call('hideOptionMenu');
}
if (typeof WeixinJSBridge == "undefined") {
    if (document.addEventListener) {
        document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);
    } else if (document.attachEvent) {
        document.attachEvent('WeixinJSBridgeReady', onBridgeReady);
        document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);
    }
} else {
    onBridgeReady();
}

vue 禁用微信分享
mounted(){
        this.wxShare();
},
methods: {
    wxShare(){
        let _this = this;
        if (typeof WeixinJSBridge == "undefined") {
            if (document.addEventListener) {
            document.addEventListener('WeixinJSBridgeReady',
                _this.onBridgeReady, false);
            } else if (document.attachEvent) {
            document.attachEvent('WeixinJSBridgeReady',
                _this.onBridgeReady);
            document.attachEvent('onWeixinJSBridgeReady',
                _this.onBridgeReady);
            }
        } else {
            _this.onBridgeReady();
        }
    },
    onBridgeReady:function(){
        WeixinJSBridge.call('hideOptionMenu');
    },
}

IOS 系统 中文参数 encode解码

//IOS 不支持中文参数 Android 支持解码中文参数
that.encriptStr = '?openId=' + that.openId + '&mobile=' + that.mobile + '&agentCode=' + that.agentCode + '&userName=' + encodeURI(that.userName);
//移动端键盘弹起导致屏幕下方定位的按钮被顶起
var win_h = $(window).height();
window.addEventListener('resize', function () {
    if($(window).height() < win_h){
        $('.bottom_nav').hide();
    }else{
        $('.bottom_nav').show();
    }
});
//是否微信浏览器
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i)=="micromessenger") {
  console.log('微信浏览器');
} else {
  console.log('非微信浏览器');
}
采用正则表达式获取地址栏参数
function getUrlName(name) {
    var url = window.location.search;
    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
    var result = url.substr(1).match(reg);
    return result ? decodeURIComponent(result[2]) : null;
}
 
// 调用方法
alert(getUrlName("参数名1"));
alert(getUrlName("参数名2"));
alert(getUrlName("参数名3"));
<!-------- rem布局算法 设计稿750px -------->
(function(doc, win) {
    var docEl = doc.documentElement,
        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
        recalc = function() {
            var clientWidth = docEl.clientWidth;
            if (!clientWidth) return;
            if(clientWidth >= 750) clientWidth = 750;
            docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
            /*docEl.style.fontSize = 20 * (clientWidth / 320) + 'px';*/
        };
    if (!doc.addEventListener) return;
    win.addEventListener(resizeEvt, recalc, false);
    doc.addEventListener('DOMContentLoaded', recalc, false);
})(document, window);
<!-------- rem布局算法 设计稿750px -------->
/* 兼容华为原生浏览器flex布局 */
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;

-webkit-box-pack: justify;
-moz-justify-content: space-between;
-webkit-justify-content: space-between;

-webkit-box-align: center;
-moz-align-items: center;
-webkit-align-items: center;

-webkit-box-direction: normal;
-webkit-box-orient: horizontal;
-moz-flex-direction: row;
-webkit-flex-direction: row;

-webkit-box-flex: 1;
-ms-flex: 1;
//css tips
//CheckBox, radio 点击后面的文字 也可勾选
<input type="radio" id="male" name="sex" checked="checked" /><label for="male">男</label>  
给 label标签添加for属性,值为input的id值

//伪类 设置placeholder样式
#input-test::-webkit-input-placeholder{
        color: #ADD8E6;
}

//fixed定位超出父级宽度
.header{
  position: fixed;
  top:0;
  width: 100%;
  left: 50%;
  transform: translateX(-50%);
  max-width: 750px;
  height: 2rem;
  background:#EB2926;
}

//超出部分变为省略号
width: 300px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;

//超出2行部分 变为省略号
text-overflow: -o-ellipsis-lastline;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2; //这儿的数字代表的就是你所需要实现效果的第N行
-webkit-box-orient: vertical;

二维码 兼容小米华为 解决长摁不识别二维码bug 原因在于生成的img标签 没有src属性

creatQrCode(){
    let _this = this 
    var qrcode = new QRCode(this.$refs.qrCodeUrl, {
        text: "https://"+window.location.host+"/#/recommend/register" + _this.encriptStr,
        width: 200,
        height: 200,
        colorDark: '#000000',
        colorLight: '#ffffff',
        correctLevel: QRCode.CorrectLevel.H
    });
    // qrcode.makeCode(url);
    var canvas=document.getElementsByTagName('canvas')[0];
    var img = convertCanvasToImage(canvas);
    document.getElementById('qrcode').append(img);// 添加DOM
    //从 canvas 提取图片 image
    function convertCanvasToImage(canvas) {
        //新建Image对象
        var image = new Image();
        // canvas.toDataURL 返回的是一串Base64编码的URL
        image.src = canvas.toDataURL("image/png");  
        return image; 
    }
},
上一篇 下一篇

猜你喜欢

热点阅读