JavaScript---网络编程(3)-Object、String、Array对象和prototype属性-2

简介: JavaScript---网络编程(3)-Object、String、Array对象和prototype属性-1

prototype属性的用法演示


返回对象类型原型的引用。

objectName.prototype

objectName 参数是对象的名称。


JS是基于对象的,用对象的时候都是临时去读取复制原型的,这个属性,就是改变那个原型的。


用 prototype 属性提供对象的类的一组基本功能。 对象的新实例“继承”赋予该对象原型的操作。


代码演示:

<html>
  <head>
    <title>prototype属性的用法演示</title>
  </head>
  <body>
    <script type="text/javascript" src="out.js">
    </script>
    <script type="text/javascript">
      //※※※利用prototype更改原型时,如果属性或方法已经存在那么是修改,否则就是添加。
      //※※给String原型对象添加一个属性aa
       String.prototype.aa=100;
       var str = "abc123";
       println( str.aa );
       println( "aw12".aa );//只要是String型的,都能调用aa,结果都是100
    </script>
    <script type="text/javascript">
      //※※给String原型对象添加一个函数---以trim()为例--去前后空格
      //☆☆过渡版
      function trim(str){
         var start=0;
         var end = str.length-1;
         while(start<=end && str.charAt(start)==' '){
             start++;
         }
         while(start<=end && str.charAt(end)==' '){
             end--;
         }
         return str.substring(start,end+1); 
      }
      println( trim("   ewwewe  ewwewe   ") );
      //println( "   ewwewe  ewwewe   ".trim() );
    </script>
    <!-- 
        <script type="text/javascript">
          //※※给String原型对象添加一个函数---以trim()为例
          //不用传参,将str改为this就可以了。
          //☆☆法1---用非匿名函数
          function trim(){
             var start=0;
             var end = this.length-1;
             while(start<=end && this.charAt(start)==' '){
                 start++;
             }
             while(start<=end && this.charAt(end)==' '){
                 end--;
             }
             return this.substring(start,end+1); 
          }
          String.prototype.trim=trim;//给原型对象添加一个trim()方法
          println( "  yyy 666   ".trim() );
        </script>
     -->
    <script type="text/javascript">
      //※※给String原型对象添加一个函数---以trim()为例
      //☆☆法2---用匿名函数
      String.prototype.trim= function(){ //给原型对象添加一个trim()方法
         var start=0;
         var end = this.length-1;
         while(start<=end && this.charAt(start)==' '){
             start++;
         }
         while(start<=end && this.charAt(end)==' '){
             end--;
         }
         return this.substring(start,end+1); 
      };
      println( "  yyrry 666888   ".trim() );
      var sstr = new String("  www eee  ");
      println( sstr.trim() );
    </script>
  </body>
</html>


360浏览器8.1 演示结果:

image.png

prototype扩展:

我们现在扩展一下,假如我们先写好js,再导入,就可以直接用我们自己写的那个函数,那个值了。

<html>
  <head>
    <title>利用prototype属性给API进行功能扩展</title>
  </head>
  <body>
    <script type="text/javascript" src="out.js">
    </script>
    <script type="text/javascript" src="stringtools.js">
    </script>
    <script type="text/javascript">
       var str="   hjdsh  ";
       println( str.trim() );//去掉字符串前后空格
       println( str.toCharArray() );//字符串转换为字符数组
       var str2 = "abc123";
       println( str2 );
       println( str2.reverse() );//字符串反转输出
    </script>
  </body>
</html>

stringtools.js的代码:

//给原型对象添加一个trim()方法
String.prototype.trim = function() {
    var start = 0;
    var end = this.length - 1;
    while (start <= end && this.charAt(start) == ' ') {
        start++;
    }
    while (start <= end && this.charAt(end) == ' ') {
        end--;
    }
    return this.substring(start, end + 1);
};
// 给原型对象添加一个toCharArray()方法
String.prototype.toCharArray = function() {
    var chs = [];
    for ( var x = 0; x < this.length; x++) {
        chs[x] = this.charAt(x);
    }
    return chs;
};
// 给原型对象添加一个reverse()方法 
String.prototype.reverse = function() {
    //☆☆js中,函数当中可以再定义函数--内部函数
    function swap(arr,x,y){
        var temp = arr[x];
        arr[x] = arr[y];
        arr[y] = temp;
    }
    var arr = this.toCharArray();
    for(var x=0,y=arr.length-1; x<y; x++,y--){
        swap(arr,x,y);
    }
    return arr.join("");//join(str)方法-返回字符串,str就是连接数组元素之间的符号。
};

360浏览器8.1 演示结果:

image.png

Array对象使用方法

代码演示:

<html>
  <head>
    <title>Array对象使用方法演示</title>
  </head>
  <body>
    <script type="text/javascript" src="out.js">
    </script>
   <script type="text/javascript">
     var arr=["aaa","bbb","ccc","ddd"];
     println(arr);
     var arr2=["111","222","333","okok"];
     var newArr = arr.concat(arr2);
     println(newArr);
     println(newArr.join("-"));
     println("<hr/>");
     //pop() :  移除数组中的最后一个元素并返回该元素。
     println( newArr.pop() );
     println(newArr);
     //push() : 将新元素添加到一个数组中,并返回数组的新长度值。
     arr.push("x1",arr2,"x2");//注意1,arr2在arr当中是一个元素---即arr变成二维数组。注意2,push方法会改变原来的数组。arr长度为:9
     println(arr+"----二维数组了");
     println(arr.length);
     //arr.push("y1",arr2,"z1");//注意1,arr2在arr当中是一个元素---即arr变成二维数组。注意2,push方法会改变原来的数组。arr长度为:9
     arr=arr.concat("y1",arr2,"z1");
     //注意1,该方法会把数组arr2当中的每个元素取出来,分别添加到arr当中---arr还是一维数组
     //注意2,concat方法不会改变原来的数组,连接结果以新数组的形式返回。旧arr的长度还是6,新arr的长度是12
     println(arr);
     println(arr.length);
     arr.sort();
     println(arr);
     arr.splice(1, 3, "u1","u2","u3","u4","u5");//从1位置开始,删掉3个元素,并且在删除的位置插入:"u1","u2","u3","u4","u5"
     println(arr);
     //※※※做栈和队列的提示
     //unshift---addFirst  concat--addLast()  shift---removeFirst()  pop---removeLast()
     //Array.prototype.addFirst=unshift;
   </script>
    <script type="text/javascript" src="arraytools.js">
    </script>
    <script type="text/javascript">
       var arr=["aaa","bbb","ccc","ddd"];
       var max = arr.getMax();
       println(max);
       println(arr);
    </script>
  </body>
</html>

arraytools.js代码:


//给原型对象添加一个getMax()方法
Array.prototype.getMax = function() {
    var temp=0;
    for(var x=1;x<this.length;x++){
        if(this[x]>this[temp]){
            temp = x;
        }
    }
    return this[temp];
};
Array.prototype.toString = function() {
    return "["+this.join("")+"]";
};

360浏览器8.1 演示结果:

image.png

prototype属性真的很强大~~~

目录
相关文章
|
8月前
|
存储 消息中间件 人工智能
【05】AI辅助编程完整的安卓二次商业实战-消息页面媒体对象(Media Object)布局实战调整-按钮样式调整实践-优雅草伊凡
【05】AI辅助编程完整的安卓二次商业实战-消息页面媒体对象(Media Object)布局实战调整-按钮样式调整实践-优雅草伊凡
246 11
【05】AI辅助编程完整的安卓二次商业实战-消息页面媒体对象(Media Object)布局实战调整-按钮样式调整实践-优雅草伊凡
|
10月前
|
JavaScript 前端开发 开发者
讲述Vue框架中用于对象响应式变化的Object.defineProperty函数。
综上所述,Vue.js通过 `Object.defineProperty()`提供了强大的响应式能力,使得状态管理变得简洁高效。这种能力是Vue.js受到广大开发者青睐的重要原因之一。尽管Vue 3.x使用Proxy替代了该方法,但对于Vue 2.x及其之前版本,`Object.defineProperty()`是理解Vue.js内部工作机制不可或缺的一部分。
285 27
|
编解码 JavaScript 前端开发
【Java进阶】详解JavaScript的BOM(浏览器对象模型)
总的来说,BOM提供了一种方式来与浏览器进行交互。通过BOM,你可以操作窗口、获取URL、操作历史、访问HTML文档、获取浏览器信息和屏幕信息等。虽然BOM并没有正式的标准,但大多数现代浏览器都实现了相似的功能,因此,你可以放心地在你的JavaScript代码中使用BOM。
369 23
|
安全 Java
Object取值转java对象
通过本文的介绍,我们了解了几种将 `Object`类型转换为Java对象的方法,包括强制类型转换、使用 `instanceof`检查类型和泛型方法等。此外,还探讨了在集合、反射和序列化等常见场景中的应用。掌握这些方法和技巧,有助于编写更健壮和类型安全的Java代码。
960 17
|
前端开发 数据处理
对象数据的读取,看这一篇就够了!Object.keys()、Object.values()和Object.entries()用法详解;如何获取对象原型链上的属性
Object.keys()、Object.values()和Object.entries()都是利于对象操作的便捷方法,能有效提升数据处理的效率。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
JSON 前端开发 JavaScript
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
287 1
JavaScript中对象的数据拷贝
|
安全 IDE Java
重学Java基础篇—Java Object类常用方法深度解析
Java中,Object类作为所有类的超类,提供了多个核心方法以支持对象的基本行为。其中,`toString()`用于对象的字符串表示,重写时应包含关键信息;`equals()`与`hashCode()`需成对重写,确保对象等价判断的一致性;`getClass()`用于运行时类型识别;`clone()`实现对象复制,需区分浅拷贝与深拷贝;`wait()/notify()`支持线程协作。此外,`finalize()`已过时,建议使用更安全的资源管理方式。合理运用这些方法,并遵循最佳实践,可提升代码质量与健壮性。
464 1
课时78:Object类的基本概念
Object类的主要特点是可以解决参数的统一问题,使用object类可以接受所有的数据类型。 1. Object类简介 2. 观察Object类接收所有子类对象 3. 使用Object类接收数组
260 0
|
JSON Java Apache
Java基础-常用API-Object类
继承是面向对象编程的重要特性,允许从已有类派生新类。Java采用单继承机制,默认所有类继承自Object类。Object类提供了多个常用方法,如`clone()`用于复制对象,`equals()`判断对象是否相等,`hashCode()`计算哈希码,`toString()`返回对象的字符串表示,`wait()`、`notify()`和`notifyAll()`用于线程同步,`finalize()`在对象被垃圾回收时调用。掌握这些方法有助于更好地理解和使用Java中的对象行为。
263 8
|
Java
Java Object 类详解
在 Java 中,`Object` 类是所有类的根类,每个 Java 类都直接或间接继承自 `Object`。作为所有类的超类,`Object` 定义了若干基本方法,如 `equals`、`hashCode`、`toString` 等,这些方法在所有对象中均可使用。通过重写这些方法,可以实现基于内容的比较、生成有意义的字符串表示以及确保哈希码的一致性。此外,`Object` 还提供了 `clone`、`getClass`、`notify`、`notifyAll` 和 `wait` 等方法,支持对象克隆、反射机制及线程同步。理解和重写这些方法有助于提升 Java 代码的可读性和可维护性。
591 20