前端实用方法(持续更新...)

iframe对象

1.父级页面获取iframe页面中的元素对象(关键contentWindow):

document.getElementById(iframe的id).contentWindow.document.getElementById(iframe页面元素id)

2.iframe页面获取父级页面的元素对象(关键window.parent):

window.parent.document.getElementById(父级页面的元素id)

js touchstart touchend监听滑动

$('#recordList li').on('touchstart', function(e){ 
    startX = e.originalEvent.changedTouches[0].pageX, 
    startY = e.originalEvent.changedTouches[0].pageY;
 });

$('#recordList li').on('touchmove',function(e){
    //获取滑动屏幕时的X,Y
    endX = e.originalEvent.changedTouches[0].pageX,
    endY = e.originalEvent.changedTouches[0].pageY;
    //获取滑动距离
    distanceX = endX-startX;
    distanceY = endY-startY;
    //判断滑动方向
    if(Math.abs(distanceX)>Math.abs(distanceY) && distanceX>0){
        console.log('往右滑动');
    }else if(Math.abs(distanceX)>Math.abs(distanceY) && distanceX<0){
        console.log('往左滑动');
    }else if(Math.abs(distanceX)0){
        console.log('往下滑动');
    }else{
        console.log('点击未滑动');
    }

});

JS传递参数

js所有函数中的参数都是按值传递的,也就是说,将函数外部的值复制给函数内部的参数。

  1. 向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(即arguments对象中的一个元素)
  2. 在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的值会反映在函数外部。
// 传递基本类型的值
function add(num) {
    num += 10;
    return num;
}    
var count = 20;
var result = addTen(count);
console.log(count)  // 20
console.log(result)  // 30

函数参数使用对象,按值传递,但是会按引用类型来访问同一对象

function setName(obj) {
    obj.name = 'bear_new';    
}
var person = new Object();
setName(person);    // 函数内的参数obj变化,函数外部的person也会发生改变,obj和person引用同一对象,指向的对象在堆内存中只有一个,而且是全局对象
alert(person.name);    // 'bear_new'

给函数参数对象重新赋值

var person = new Object();
setName(person);
alert(person.name);   // 'bear_new'

function setName() {
    obj.name = 'bear_new';
    obj = new Object();   // 此时给obj重新赋值新变量,将obj变成了局部对象,即使修改,原始的引用仍然保持未变,并且局部对象会在函数执行完后立即被销毁
    obj.name = 'Greg';
}

js对象深拷贝

function deepCopy(source) { 
    var result={};
    for (var key in source) {
          result[key] = typeof source[key]==='object'? deepCopy(source[key]): source[key];
       } 
       return result; 
}

h5 contenteditable属性 focus方法

var p = document.getElementById('contentEditableElementId'),
    s = window.getSelection(),
    r = document.createRange();
r.setStart(p, 0);
r.setEnd(p, 0);
s.removeAllRanges();
s.addRange(r);

对图片进行等比例缩放居中(解决图片固定宽高导致的图片变形体验不佳)

var $img = $('#upload');
var imgtemp = new Image();//创建一个image对象
    if ( $img.attr('src')!==undefined ) {
        imgtemp.src = $img.attr('src')
        imgtemp.onload = function(){//图片加载完成后执行
        realWidth = this.width;
        realHeight = this.height;
        autoSizeImg($img,realWidth,realHeight, 65, 60);
    }
/*
* 图片等比例缩放并居中
* w:原图真实宽度 h:原图真实高度
* maxWidth: 需要缩放的realWidth,宽度 maxHeight: 需要缩放的高度
*/
function autoSizeImg( $img, w, h, maxWidth, maxHeight){
      var Ratio = 1; //图片缩放比例
      var wRatio = maxWidth/w; //图片横向缩放比例
      var hRatio = maxHeight/h; //图片纵向缩放比例
                wRatio>hRatio ? Ratio = wRatio : Ratio = hRatio;
                $img.width(w*Ratio);
        $img.height(h*Ratio);

        if(w*Ratio > maxWidth){
            var left = -(w*Ratio-maxWidth)/2 + 'px';
            $img.css('margin-left', left)
        }
        if(h*Ratio > maxHeight){
            var top = -(h*Ratio-maxHeight)/2 + 'px';
            $img.css('margin-top', top)
        }
    }

excel表格导出







1admin 23程序员 天津[email protected]
2guest 23测试员 北京[email protected]

你可能感兴趣的:(前端实用方法(持续更新...))