09-JS使用过的函数 81-90

81、delete

delete 关键字 删除某个对象的属性, 返回值是布尔类型, true删除成功,false删除失败(不可以删除)

delete object.property // 删除对象属性
delete object[index] // 删除数组元素

需要注意的是,delete 操作符只是删除了属性或元素本身,而不会删除它们所占用的内存空间,因此并不会释放内存。此外,delete 操作符只能删除可配置的属性,对于不可配置的属性,比如通过object.property 方法定义的属性,是无法删除的。

82、Object.defineProperty

Object.defineProperty 是 JavaScript 中用于定义对象属性的方法。它接受三个参数:要定义属性的对象、要定义的属性名称以及描述符对象。描述符对象包含属性的特性,例如可写性、可枚举性、可配置性等。通过 Object.defineProperty方法定义的属性,可以更精细地控制属性的行为。 

const obj = {};
// 定义一个名为 "name" 的属性
Object.defineProperty(obj, 'name', 
                     {
                         value: 'John',  
                         writable: false, // 不能被重写  
                         enumerable: true, // 可以被枚举  
                         configurable: false // 不能被删除
                     });
console.log(obj.name); // 输出 "John"
obj.name = 'Mike'; // 不起作用,因为 writable 属性被设置为 false
console.log(obj.name); // 输出 "John"
delete obj.name; // 不起作用,因为 configurable 属性被设置为 false
console.log(obj.name); // 输出 "John"

 83、search

search() 检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子字符串的起始位置; 如果找不到返回

var str1 = 'abcdef';
console.log(str1.search('g')); // -1
console.log(str1.search('cd')); // 2
console.log(str1.search('cf')); // -1

84、substring

substring() 方法用于提取字符串中介于两个指定下标之间的字符。

substring() 方法返回的子串包括 开始 处的字符,但不包括 结束 处的字符。

<script>

var str="Hello world!";
document.write(str.substring(3)+"<br>");
document.write(str.substring(3,7));

</script>

以上例程会输出: 

lo world!
lo w 

 85、exec

exec() 方法用于检索字符串中的正则表达式的匹配。

如果字符串中有匹配的值返回该匹配值,否则返回 null。

在字符串中全局搜索 "Hello" 和 "RUNOOB" 字符串:

var str="Hello world!";
//查找"Hello"
var patt=/Hello/g;
var result=patt.exec(str);
document.write("返回值: " +  result); 
//查找 "RUNOOB"
patt=/RUNOOB/g;
result=patt.exec(str);
document.write("<br>返回值: " +  result);

 以上实例输出结果:

Returned value: Hello
Returned value: null

86、match

match是 JavaScript 中字符串对象的一个方法,用于在字符串中查找一个或多个匹配的子字符串,并返回匹配结果。语法如下:

str.match(regexp)

其中,str 是要查找的字符串,regexp是一个正则表达式对象或字符串,用于指定匹配规则。如果 regexp是一个字符串,它将首先被转换为一个正则表达式对象。

match方法返回一个数组,其中包含所有匹配的子字符串及其捕获组(如果有)。如果没有找到匹配的子字符串,则返回 null。

例如,以下代码将在字符串中查找所有以字母 "a" 开头的单词,并打印它们的数量:

const str = "An apple a day keeps the doctor away.";
const matches = str.match(/\ba\w*/g);
console.log(matches.length); // 输出 2

上述代码中,正则表达式 \ba\w* 匹配以字母 "a" 开头的单词,\b 表示单词边界,\w* 匹配零个或多个字母数字字符。g 标志表示全局匹配,即查找所有匹配的子字符串。

 87、test

test() 方法用于检测一个字符串是否匹配某个模式.

如果字符串中有匹配的值返回 true ,否则返回 false。

在字符串中全局搜索 "Hello" 和 "Runoob" 字符串: 

var str="Hello world!";
//查找"Hello"
var patt=/Hello/g;
var result=patt.test(str);
document.write("返回值: " +  result); 
//查找 "Runoob"
patt=/Runoob/g;
result=patt.test(str);
document.write("<br>返回值: " +  result);

以上例程会输出: 

返回值: true
返回值: false

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

七色的天空

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值