JavaScript基础插曲---apply,call和URL编码等方法

简介: JavaScript基础插曲---apply,call和URL编码等方法

Js基础学习



Js的压缩:


就是利用js的语法格式通过缩短变量名,去掉空格等来进行压缩。

Apply和call的使用


1:apply方法:应用某一对象的方法,用于一个对象替换当前对象。主要是改变this的值。

    <script type="text/javascript">
        var user_name = "阿辉";
        //一个函数,这里主要注意里面的this的含义。
        function showName() {
            alert(this.user_name);
        };
        var p = { user_name: '阿红' };
        showName.apply(p);// 这里通过apply方法来改变函数中this的不同。这里的p就是this.
    </script>



2:call方法:这个和上面的方法是一样的,只是当需要有参数的时候需要逗号来区别,而apply是通过数组的形式来传递的。


这里就是有参数的时候,我们使用apply的时候需要使用数组的形式来传递。

    var user_name = "阿辉";
    //一个函数,这里主要注意里面的this的含义。
    function showName(a,b,c) {
        alert(this.user_name);
        alert(a + b + c);
    };
    var p = { user_name: '阿红' };
    showName.apply(p);// 这里通过apply方法来改变函数中this的不同。这里的p就是this.
    showName.apply(p, [12,12,12]);
    showName.call(p,13,13,13);



上面的代码就是二者的区别。使用的时候我们需要注意这些小的知识点。


函数的递归:


当函数是匿名函数的时候我们使用递归的时候里面的值千万不要直接写赋值的匿名函数,我们需要通过arguments.callee();来表示函数自身。

    var index = 0;
    //定义匿名函数
    var s = function() {
        index++;
        alert(index);
        if (index<5) {
            //s();
            arguments.callee();//表示函数自身
        }
    };
    var ss = s;
    ss();



encodeURL方法:将文本字符串编码为一个有效的统一资源标识符(URL),这个方法不会对那些特殊的字符进行编码,这时我们需要使用encodeURLCompoment方法对这些字符进行编码。这个编码的范围更加的广。


    var msg = 'http://localhost:55186/js%E7%BB%83%E4%B9%A0/js11.html';
    var url_value = window.encodeURI(msg); //只编码文本的字符串
    var sss = window.encodeURIComponent(msg);//编码更加的广泛,前面的数字都进行了编码。
    alert(sss);
    alert(url_value);


679140-20160304212450127-966099210.png

679140-20160304212450502-392525049.png


Eg:点击实现展示关闭2级菜单。


思路:通过为

标签来注册单击事件,接着找到它下面的

    ,看是否隐藏,在进行操作。{思路很重要,每次的代码都是那样子,只需要学会解决问题的想法,这样就可以以此类推,解决很多的问题。}



    <body>
        <ul id="umenu">
            <li>
                <p>111</p>
                <ul>
                    <li>1</li>
                    <li>2</li>
                    <li>3</li>
                </ul>
            </li>
            <li>
                <p>222</p><ul><li>1</li><li>2</li><li>3</li></ul>
            </li>
            <li>
                <p>333</p><ul><li>1</li><li>2</li><li>3</li></ul>
            </li>
        </ul>
    </body>


Js代码如下:

    window.onload = function () {
          //为每个菜单项注册单击事件
          var ps = document.getElementById('umenu').getElementsByTagName('p');
          //遍历ps,为每个注册单击事件
          for (var i = 0; i < ps.length; i++) {
              ps[i].onclick = function () {
                  //1;找到p后面的<ul>,+this.parentNode是找到其父节点;
                  var x = this.parentNode.getElementsByTagName('ul')[0];
                  //2:判断是否隐藏
                  if (x.style.display != 'none') {
                      x.style.display = 'none';
                  } else {
                      x.style.display = 'block';
                  }
              };
          }
      };



679140-20160304212451049-897022436.png


目录
相关文章
|
16天前
|
前端开发 JavaScript 开发者
揭秘JavaScript魔法三剑客:call、apply、bind,解锁函数新世界,你的前端之路因它们而精彩!
【8月更文挑战第23天】在 JavaScript 的世界里,`call`、`apply` 和 `bind` 这三个方法常常让新手感到困惑。它们都能改变函数执行时的上下文(即 `this` 的指向),但各有特点:`call` 接受一系列参数并直接调用函数;`apply` 则接收一个参数数组,在处理不确定数量的参数时特别有用;而 `bind` 不会立即执行函数,而是创建一个新版本的函数,其 `this` 上下文已被永久绑定。理解这三个方法能帮助开发者更好地运用函数式编程技巧,提升代码灵活性和可维护性。
23 0
|
19天前
|
JavaScript 前端开发
js获取url参数值的几种方式
js获取url参数值的几种方式
|
1月前
|
机器学习/深度学习 JavaScript
node.js实现遍历所有文件夹里面的js文件,提取所有的url
node.js实现遍历所有文件夹里面的js文件,提取所有的url
|
16天前
|
JavaScript 前端开发
js 中call()和apply()
js 中call()和apply()
26 0
|
24天前
|
JavaScript 前端开发
JS - 如何上传 Base64 编码的图片
本文展示了如何将Base64编码的图片在前端转换为Blob对象,并使用`FormData`上传到服务器端的方法。
118 0
|
1月前
|
JavaScript 前端开发
深入浅出 妙用Javascript中apply、call、bind
【8月更文挑战第1天】深入浅出 妙用Javascript中apply、call、bind
18 0
|
2月前
|
JavaScript
js【详解】bind()、call()、apply()( 含手写 bind,手写 call,手写 apply )
js【详解】bind()、call()、apply()( 含手写 bind,手写 call,手写 apply )
19 0
|
24天前
|
开发框架 前端开发 .NET
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
|
28天前
|
Java
JAVA 获取 URL 指定参数的值
JAVA 获取 URL 指定参数的值
28 0
|
2月前
|
JavaScript 前端开发 数据格式
URL编码【详解】——Javascript对URL进行编码解码的三种方式的区别和使用场景,axios请求拦截器中对get请求的参数全部进行URL编码
URL编码【详解】——Javascript对URL进行编码解码的三种方式的区别和使用场景,axios请求拦截器中对get请求的参数全部进行URL编码
53 0