首頁 > web前端 > js教程 > JavaScript進階學習之初識類別、函數進階、如何改變this指向

JavaScript進階學習之初識類別、函數進階、如何改變this指向

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2022-11-22 16:06:43
轉載
1709 人瀏覽過

這篇文章為大家帶來了關於JavaScript的相關知識,其中主要介紹了類別、函數進階以及如何改變this指向的相關內容,希望對大家有幫助。

JavaScript進階學習之初識類別、函數進階、如何改變this指向

【相關推薦:JavaScript影片教學web前端

##1.class類別

1.1class本質還是function

# 1.2類別的所有方法定義在類別的prototype屬性上

#1.3類別所建立的實例,裡面也有_ proto_ 指向類別的prototype原型物件

1.4語法糖

ES6的類它的絕大部分功能, ES5都可以做到,而class寫法只是讓對象原型的寫法更加清晰、更像面向對象編程的語法而已, 語法糖就是一種便捷寫法. 簡單理解,有兩種方法可以實現相同的功能,但是一種寫法更加清晰、 方便那麼這個方法就是語法糖,對於es5來說es6就是語法糖

這倆看起來,那個比較簡單呢?對就是第二個(別槓),這就是語法糖2.數組方法

 2.1forEach

#語法:數組.forEach(回呼函數(value:數組當前項值,index:數組當前索引,array:數組本身))
 <script>
        var arr = [5, 6, 7];
        var sum = 0;
        arr.forEach(function (value, index, array) {
            console.log(value);
            sum += value;
        })
        console.log(sum);
    </script>
登入後複製

#2.1filter(過濾元素)  

主要是用來篩選數組的(迭代遍歷後得到的是數組,所以需要接受)

  // filter
        var arr1 = [12, 34, 5, 66, 78, 0];
        // 由于filter返回的是一个新数组所以需要接收一下newArray
        var newArray = arr1.filter(function (value, index) {
            // 找到小于10 的数
            return value < 10;
        })
        console.log(newArray);
登入後複製

2.3some

(校驗元素)  

#用來找出陣列中是否有滿足條件的元素(傳回值是一個Boolean的值,有該查找的元素就回傳true,沒有的話就回傳false,當查找到第一個滿足的元素時,則會停止找)

 var arr = [2, 3, 4, 5, 6];
        var newArr= arr.some(function (value, index) {
            return value % 3 === 0;
        })
        console.log(newArr);
登入後複製
依序判斷,先從第一個元素開始,看是否滿足條件如果不滿足條件則接著查找,如果滿足條件則回傳true,如果沒有任何一個元素滿足條件則回傳false

2.4map資料渲染

var fileBlog= [
        {
            title: &#39;【JavaScript——初始JS】&#39;,
            url: &#39;https://blog.csdn.net/zhaochen1127/article/details/125956545?spm=1001.2014.3001.5501&#39;,
            intr: &#39;本文是一篇对js萌新极其友好的一篇文章....&#39;
    
        }, {
            title: &#39;【JavaScript——初始JS】&#39;,
            url: &#39;https://blog.csdn.net/zhaochen1127/article/details/125956545?spm=1001.2014.3001.5501&#39;,
            intr: &#39;本文是一篇对js萌新极其友好的一篇文章....&#39;
        }, {
            title: &#39;【JavaScript——初始JS】&#39;,
            url: &#39;https://blog.csdn.net/zhaochen1127/article/details/125956545?spm=1001.2014.3001.5501&#39;,
            intr: &#39;本文是一篇对js萌新极其友好的一篇文章....&#39;
        }
    ]
    var fblog = fileBlog.map(function (item) {
        return `
            <li>
                <h5>${item.title}</h5>
                <p>${item.intr}</p>
                <a href="${item.url}" target="_blank">阅读博客</a>
            </li>
            `
    })
    var ul = document.querySelector('.blogs').querySelector('.bcon').querySelector('.blist');
    console.log( fblog.join(''));
     ul.innerHTML = fblog.join('');
登入後複製
3.字串方法

######trim()方法###(trim不會影響字串本身的,回傳的是新的字串)###############trim指回去除兩側的空格而在字元春中間的空格不會被去除掉#########4.物件方法# ###########Object.keys()### 用來取得物件本身所有的屬性 object .keys (obj) ,效果類似for..in ,傳回一個由屬性名稱組成的陣列# ##
    var obj = {
        idcard:10086,
        uname:'山鱼',
        age:20,
        sex:'男'
    }
    var obj1 = Object.keys(obj);
    console.log(obj1);
登入後複製
###############4.1Object.defineProperty()###定義新屬性或修改原有的屬性######Object.defineProperty()第三個參數descriptor說明:以物件形式{}書寫###

4.2value设置属性的值默认为undefined

var obj = {
        idcard:10086,
        uname:'山鱼',
        age:20,
        sex:'男'
    }
    // 给obj添加一个birthday属性,属性值为‘11.27’
    Object.defineProperty(obj,'birthday',{
        value:'11.27'
    }
)
    // 修改obj里面的age属性,修改后的属性值为25
    Object.defineProperty(obj,'age',{
        value:25
    }
)
console.log(obj);
登入後複製

4.3writable 值是否可以重写true | false默认为false

 (idcard的值并没有修改 ) 

4.4enumerable 目标属性是否可以被枚举true | false默认也为false

Object.defineProperty(obj,'location',{
        value:'JingXian',
        writable:false,
        enumerable:false
    }
)
console.log(obj);
登入後複製

4.5configurabletrue| false 默认为false

目标属性是否可以被删除或是否可以再次修改特性

 Object.defineProperty(obj,'location',{
        value:'JingXian',
        writable:false,
        enumerable:false,
        configurable:false
    }
)
        delete obj.location;
        	console.log(obj);
        delete obj.uname;
        	console.log(obj);
登入後複製

也不可以再次修改里面的特性  

【相关推荐:JavaScript视频教程web前端

以上是JavaScript進階學習之初識類別、函數進階、如何改變this指向的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板