精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

別再為了this發愁了:JS中的this機制

開發 前端
JavaScript中有很多令人困惑的地方,或者叫做機制。但是,就是這些東西讓JavaScript顯得那么美好而與眾不同。比方說函數也是對象、閉包、原型鏈繼承等等,而這其中就包括頗讓人費解的this機制。不管是新手還是老手,不仔細深摳一下還真鬧不明白this倒地咋回事捏。今天,我們就一起看一下this倒地咋回事,別再為了this發愁了。

[[187723]]

題記:JavaScript中有很多令人困惑的地方,或者叫做機制。但是,就是這些東西讓JavaScript顯得那么美好而與眾不同。比方說函數也是對象、閉包、原型鏈繼承等等,而這其中就包括頗讓人費解的this機制。不管是新手還是老手,不仔細深摳一下還真鬧不明白this倒地咋回事捏。今天,我們就一起看一下this倒地咋回事,別再為了this發愁了。

1、this是啥?

簡言之,this是JavaScript語言中定義的眾多關鍵字之一,它的特殊在于它自動定義于每一個函數域內,但是this倒地指引啥東西卻讓很多人張二摸不著頭腦。這里我們留個小懸念,希望看完這篇文章了你能回答出來this到底指引個甚。

2、this有啥用?

那邊觀眾又該問了,既然this這么難以理解,那么為個甚還要用它呢?我們來看個例子:

  1. function identify() { 
  2.  
  3.     return this.name.toUpperCase(); 
  4.  
  5.  
  6. function sayHello() { 
  7.  
  8.     var greeting = "Hello, I'm " + identify.call( this ); 
  9.  
  10.     console.log( greeting ); 
  11.  
  12.  
  13. var person1= { 
  14.  
  15.     name"Kyle" 
  16.  
  17. }; 
  18.  
  19. var person2= { 
  20.  
  21.     name"Reader" 
  22.  
  23. }; 
  24.  
  25. identify.call( person1); // KYLE 
  26.  
  27. identify.call( person2); // READER 
  28.  
  29. sayHello.call( person1); // Hello, I'm KYLE 
  30.  
  31. sayHello.call( person2); // Hello, I'm READER  

這段代碼很簡單,我們定義了兩個函數,分別為identify和sayHello。并且在不同的對象環境下執行了它們,達到了復用的效果,而不用為了在不同的對象環境下執行而必須針對不同的對象環境寫對應的函數了。簡言之,this給函數帶來了復用。那邊客官又問了,我不用this一樣可以實現,如:

  1. function identify(context) { 
  2.  
  3.     return context.name.toUpperCase(); 
  4.  
  5.  
  6. function sayHello(context) { 
  7.  
  8.     var greeting = "Hello, I'm " + identify( context); 
  9.  
  10.     console.log( greeting ); 
  11.  
  12.  
  13. var person1= { 
  14.  
  15.     name"Kyle" 
  16.  
  17. }; 
  18.  
  19. var person2= { 
  20.  
  21.     name"Reader" 
  22.  
  23. }; 
  24.  
  25. identify( person1); // KYLE 
  26.  
  27. identify( person2); // READER 
  28.  
  29. sayHello( person1); // Hello, I'm KYLE 
  30.  
  31. sayHello( person2); // Hello, I'm READER  

仔細一看,這位客官給出的解決方法的確也達到了類似的效果。贊一個!我想說的是,隨著代碼的增加,函數嵌套、各級調用等變得越來越復雜,那么傳遞一個對象的引用將變得越來越不明智,它會把你的代碼弄得非常亂,甚至你自己都無法理解清楚。而this機制提供了一個更加優雅而靈便的方案,傳遞一個隱式的對象引用讓代碼變得更加簡潔和復用。好了,知道了this的用處,那么再看看我們對它的誤解。

3、關于this的誤解

相信很多童鞋是學過其它語言的,在很多編程語言中都有this的機制,慣性思維把其它語言里對它的理解帶到了JavaScript中。同時,由于this這個單詞的理解導致了我們產生了對它各種各樣的誤解。所以,開始前,我們先澄清下對它的誤解。

3.1 誤解一:this引用function本身

我們都知道,在函數里引用函數可以達到遞歸和給函數屬性賦值的效果。而這在很多應用場景下顯得非常有用。所以,很多人都誤以為this就是指引function本身。例如:

  1. function fn(num) { 
  2.  
  3.     console.log( "fn: " + num ); 
  4.  
  5.     // count用于記錄fn的被調用次數 
  6.  
  7.     this.count++; 
  8.  
  9.  
  10. fn.count = 0; 
  11.  
  12. var i; 
  13.  
  14. for (i=0; i<10; i++) { 
  15.  
  16.     if (i > 5) { 
  17.  
  18.         fn( i ); 
  19.  
  20.     } 
  21.  
  22.  
  23. // fn: 6 
  24.  
  25. // fn: 7 
  26.  
  27. // fn: 8 
  28.  
  29. // fn: 9 
  30.  
  31.   
  32.  
  33. console.log( fn.count ); // 0 -- 耶?咋不是4捏?  

上面我們想要記錄fn被調用的次數,可是明顯fn被調用了四次但count仍然為0。咋回事捏?這里簡單解釋下,fn里第4行的自增隱式的創建了一個全局變量count,由于初始值為undefined,所以每一次自增其實依然不是一個數字,你在全局環境下打印count(window.count)輸出的應該是NaN。而第6行定義的函數熟悉變量count依然沒變,還是0。如果對這個執行結果不清楚的,歡迎去看我前些天的那篇博文(聊一下JS中的作用域scope和閉包closure scope和closure),在這里你只需要知道,this引用的是function這種理解是錯誤的就行。

這邊就會又有人問了,既然this不是引用function,那么我要實現遞歸函數,該咋引用呢?這里簡單回答下介個問題,兩種方法:①函數體內用函數名來引用函數本身②函數體內使用arguments.callee來引用函數(不推薦)。那么既然第二種方法不推薦,匿名函數咋引用呢?用***種,并且給匿名函數一個函數名即可(推薦)。

3.2 誤解二:this引用的是function的詞法作用域

這種誤解欺騙的人可能更多一些。首先,澄清一下,this并沒有引用function的詞法作用域。的確JS的引擎內對詞法作用域的實現的確像是一個對象,擁有屬性和函數,但是這僅僅是JS引擎的一種實現,對代碼來說是不可見的,也就是說詞法作用域“對象”在JS代碼中取不到。(關于詞法作用域,如果不理解,可以參考之前的一篇博文《聊一下JS中的作用域scope和閉包closure scope和closure》)??磦€錯誤的例子:

  1. function fn1() { 
  2.  
  3.     var a = 2; 
  4.  
  5.     this.fn2();//以為this引用的是fn1的詞法作用域 
  6.  
  7.  
  8. function fn2() { 
  9.  
  10.     console.log( this.a ); 
  11.  
  12.  
  13. fn1(); //ReferenceError  

上面的代碼明顯沒有執行出想要的結果,從而可以看到this并沒有引用函數的詞法作用域。甚至,可以肯定的說,這個例子里fn2可以在fn1里正確執行都是偶然的(理解了詞法作用域你就知道為什么這里執行不報錯了)。

4、this到底跟啥有關?

好了,扯了那么多都沒上干貨,有的觀眾都開始關閉當前頁開始離席了。這里,我們鄭重聲明:this跟函數在哪里定義沒有半毛錢關系,函數在哪里調用才決定了this到底引用的是啥。也就是說this跟函數的定義沒關系,跟函數的執行有大大的關系。所以,記住,“函數在哪里調用才決定了this到底引用的是啥”。

5、this機制的四種規則

this到底綁定或者引用的是哪個對象環境決定于函數被調用的地方。而函數的調用有不同的方式,在不同的方式中調用決定this引用的是哪個對象是由四種規則確定的。我們一個個來看。

5.1 默認綁定全局變量

這條規則是最常見的,也是默認的。當函數被單獨定義和調用的時候,應用的規則就是綁定全局變量。如下:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var a = 2; 
  7.  
  8. fn(); // 2 -- fn單獨調用,this引用window  

5.2 隱式綁定

隱式調用的意思是,函數調用時擁有一個上下文對象,就好像這個函數是屬于該對象的一樣。例如:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.     a: 2, 
  9.  
  10.     fn: fn 
  11.  
  12. }; 
  13.  
  14. obj.fn(); // 2 -- this引用obj。  

需要說明的一點是,***一個調用該函數的對象是傳到函數的上下文對象(繞懵了)。如:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj2 = { 
  7.  
  8.     a: 42, 
  9.  
  10.     fn: fn 
  11.  
  12. }; 
  13.  
  14. var obj1 = { 
  15.  
  16.     a: 2, 
  17.  
  18.     obj2: obj2 
  19.  
  20. }; 
  21.  
  22. obj1.obj2.fn(); // 42 -- this引用的是obj2.  

還有一點要說明的是,失去隱式綁定的情況,如下:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.     a: 2, 
  9.  
  10.     fn: fn 
  11.  
  12. }; 
  13.  
  14. var bar = obj.fn; // 函數引用傳遞 
  15.  
  16. var a = "全局"; // 定義全局變量 
  17.  
  18. bar(); // "全局"  

如上,第8行雖然有隱式綁定,但是它執行的效果明顯是把fn賦給bar。這樣bar執行的時候,依然是默認綁定全局變量,所以輸出結果如上。

5.3 顯示綁定

學過bind()\apply()\call()函數的都應該知道,它接收的***個參數即是上下文對象并將其賦給this??聪旅娴睦樱?/p>

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.     a: 2 
  9.  
  10. }; 
  11.  
  12. fn.call( obj ); // 2  

如果我們傳遞***個值為簡單值,那么后臺會自動轉換為對應的封裝對象。如果傳遞為null,那么結果就是在綁定默認全局變量,如:

  1. function fn() { 
  2.  
  3.      console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.      a: 2 
  9.  
  10. }; 
  11.  
  12. var a = 10; 
  13.  
  14. fn.call( null); // 10  

5.4 new新對象綁定

如果是一個構造函數,那么用new來調用,那么綁定的將是新創建的對象。如:

  1. function fn(a) { 
  2.  
  3.     this.a = a; 
  4.  
  5.  
  6. var bar = new fn( 2 ); 
  7.  
  8. console.log( bar.a );// 2  

注意,一般構造函數名首字母大寫,這里沒有大寫的原因是想提醒讀者,構造函數也是一般的函數而已。

6、結束語

讀到現在,1中問的問題你該自己能回答上來了。上面介紹的四種關于this綁定的4中情況和規則,現實寫代碼的過程中肯定比這要多和復雜,但是無論多復雜多亂,它們都是混合應用上面的幾個規則和情況而已。只要你的思路和理解是清晰的,那肯定沒問題的。 

責任編輯:龐桂玉 來源: 前端大全
相關推薦

2025-06-09 01:20:00

2021-06-16 00:57:16

JVM加載機制

2022-05-27 21:56:55

索引存儲MySQL 存儲引擎

2024-01-10 17:13:42

模型數據

2020-12-04 10:05:00

Pythonprint代碼

2020-12-02 11:18:50

print調試代碼Python

2020-06-15 08:12:51

try catch代碼處理器

2025-08-13 03:00:00

2025-05-19 04:00:00

2025-06-27 02:33:00

ServiceSpring事件

2017-08-16 09:55:36

2025-06-10 02:22:00

2025-11-03 04:00:00

2011-03-15 10:20:44

VMware環境虛擬化平臺選型

2013-12-24 13:40:13

程序員代碼

2021-06-09 06:41:11

OFFSETLIMIT分頁

2018-09-28 05:25:53

TopK算法代碼

2020-07-17 07:15:38

數據庫ID代碼

2023-10-26 07:40:15

2020-11-02 11:40:24

Node.jsRequire前端
點贊
收藏

51CTO技術棧公眾號

777精品久无码人妻蜜桃| 97色在线观看| 国产一区二区在线视频播放| 在线观看毛片网站| 色婷婷av一区二区三区丝袜美腿| 亚洲天堂a在线| 日产精品久久久一区二区福利 | 国产精品亚洲欧美| 日韩欧美综合在线| 中文字幕欧美人与畜| 神马久久久久久久| 色老板在线视频一区二区| 夜夜嗨av一区二区三区| 91精品免费久久久久久久久| av网站免费在线看| 碰碰在线视频| 成人av在线观| 久久久久久久久久国产| 又大又长粗又爽又黄少妇视频| 日韩黄色影院| 蜜桃视频一区二区三区在线观看 | 国产中文字幕日韩| 影音先锋男人在线| 亚洲天堂一区二区| 久久久久高清精品| 欧洲精品久久久| 久久无码人妻精品一区二区三区 | 色无极亚洲影院| 欧美中文字幕一区二区三区| 欧美日韩天天操| 久久国产视频精品| 影视先锋久久| 一道本成人在线| 欧美日韩国产精品一区二区| 国产精品第5页| 蜜臀91精品国产高清在线观看| 黑人极品videos精品欧美裸| 久久久99爱| 黄色片免费观看视频| 欧美精品国产白浆久久久久| 午夜天堂影视香蕉久久| 国产精品久久亚洲7777| 国内免费精品视频| 日韩影视在线观看| 色狠狠av一区二区三区| 欧美精品成人一区二区在线观看| 国产又黄又猛又粗又爽| 少妇精品久久久| 欧美午夜寂寞影院| 伊人久久大香线蕉精品| 99视频免费看| 国产精品永久| 中文字幕亚洲无线码a| 一区二区久久精品| 女人天堂av在线播放| 99国产精品99久久久久久| 欧洲日韩成人av| 五月天免费网站| 成人盗摄视频| 日本福利一区二区| 欧美做受777cos| 网站黄在线观看| 久久精品国产免费看久久精品| 久久天天躁日日躁| aaaaaaaa毛片| 狂野欧美激情性xxxx欧美| 97久久久精品综合88久久| 国产精品视频网址| 久热这里只有精品在线| 久久99高清| 欧美性生活大片免费观看网址| 青青草国产精品| 国产普通话bbwbbwbbw| 日韩视频不卡| 久久伊人91精品综合网站| 亚洲激情 欧美| 久久青草视频| 欧美日韩国产精品| 三年中国中文在线观看免费播放| 外国精品视频在线观看| 国产综合久久久久久鬼色| 91精品国产一区| 欧美做爰爽爽爽爽爽爽| 精品一区毛片| 精品久久久久99| 一级做a免费视频| 黑人精品一区| 亚洲国产视频一区| 一区二区三区四区五区精品| 少妇高潮一区二区三区69| 久久精品国产精品亚洲综合| 97婷婷大伊香蕉精品视频| 亚洲欧洲综合网| 天天做夜夜做人人爱精品| 正在播放亚洲一区| 亚洲色图久久久| 亚洲欧洲高清| 午夜精品福利久久久| 大桥未久一区二区三区| eeuss影院在线观看| 91在线视频播放| 国产激情美女久久久久久吹潮| 国产又粗又猛又黄又爽无遮挡| 欧美在线综合| 2020久久国产精品| 久久精品无码人妻| 欧美在线资源| 久久夜色精品国产欧美乱| 秋霞网一区二区三区| 国产成人影院| 亚洲视频在线观看免费| 精品人妻一区二区三区日产乱码卜| 中文字幕久久精品一区二区| 91精品国产麻豆国产自产在线| 午夜激情在线观看视频| 亚洲午夜天堂| 欧美视频13p| 国产肥臀一区二区福利视频| 波多野结衣中文字幕久久| 一区二区三区高清| 少妇大叫太大太粗太爽了a片小说| 国产传媒在线播放| 中文字幕日本不卡| 99热都是精品| 五月婷婷视频在线观看| 亚洲人成电影网站色mp4| 一区二区三区我不卡| 国产在线观看a| 亚洲精品视频在线看| 中文字幕在线乱| 天堂8中文在线| 亚洲国产日韩a在线播放性色| 国产色一区二区三区| 女海盗2成人h版中文字幕| 精品女同一区二区三区在线播放| www.av中文字幕| av日韩亚洲| 欧美午夜电影一区| 国产精品久久久久久9999| 国产精品一区免费在线 | 国产91精品久久久久久| 无码人妻精品一区二区| 青青草国产精品97视觉盛宴| 成人激情视频网| www视频在线| 91免费视频网址| 宅男在线精品国产免费观看| 亚洲妇熟xxxx妇色黄| 精品成人乱色一区二区| 亚洲综合在线网站| 国产午夜亚洲精品一级在线| 精品美女在线播放| 欧洲av一区二区三区| 99热国内精品| 国内精品久久久久影院优| 日韩 欧美 综合| 日本欧美加勒比视频| av一区观看| 国产午夜在线视频| 亚洲另类中文字| 国产最新免费视频| 国产精品一区二区精品| 日韩久久精品成人| 少妇aaaaa| 久久免费黄色| 91久久精品国产91久久性色tv| 日本激情一区二区| 国产精品美女久久久久aⅴ| 丁香色欲久久久久久综合网| 天堂√8在线中文| 欧美一区二区三区四区五区| 中文人妻一区二区三区| 亚洲一区 二区 三区| 国产成人精品视| 亚洲精品国产精品国| 国产欧美精品一区aⅴ影院 | 欧美一区二区三区的| av网站免费在线播放| 亚洲欧美综合| 国产日韩欧美视频| 丝袜视频国产在线播放| 一区二区三区中文免费| 性chinese极品按摩| 奇米影视777在线欧美电影观看| www日韩中文字幕在线看| 丰满少妇乱子伦精品看片| 国产九色精品成人porny| 日本高清视频一区二区三区| 俺来也官网欧美久久精品| 欧美巨大另类极品videosbest | 日本www.色| 精品五月天堂| 久久精品91久久久久久再现| 亚洲图片在线视频| 成人免费黄色大片| 97精品国产97久久久久久粉红| 久久久成人av毛片免费观看| 日韩精品黄色网| 免费麻豆国产一区二区三区四区| 免费人成在线不卡| 欧美婷婷久久| 在线观看v片| 亚洲福利在线观看| 国产va在线播放| 久久国产成人午夜av影院| 欧美日韩免费观看一区| 白浆在线视频| 亚洲第一区中文99精品| 九九免费精品视频| 久久99久久久欧美国产| 亚洲日本欧美在线| 黄色免费在线播放| 国产午夜精品一区二区三区四区| 亚洲一区二区影院| 国产一区福利视频| 在线视频1区2区| 日韩欧美在线国产| 日韩精品一区二区免费| yiren22亚洲综合| 亚洲美女在线视频| 妺妺窝人体色www婷婷| 国产又粗又猛又爽又黄91精品| 亚洲精品视频一二三| 亚洲天堂免费电影| 日韩精品在线观看网站| 网爆门在线观看| 日韩成人视屏| xxxxx成人.com| 一级黄色短视频| 亚洲欧美另类综合偷拍| 精品国产鲁一鲁一区二区三区| 久久人人99| 91中文精品字幕在线视频| 国产一级片免费观看| av毛片精品| 欧美高清在线播放| 精品人妻无码一区二区色欲产成人| 亚洲精品你懂的| 国产欧美一区二| 欧美成人国产| 国产一区二区中文字幕免费看| 熟女少妇内射日韩亚洲| 欧美日韩国产亚洲一区| 成人在线观看网址| 爱啪视频在线观看视频免费| 亚洲黄色片网站| 日本免费精品视频| 国产精品国产成人国产三级 | 88在线观看91蜜桃国自产| www.com.av| 国产成人精品午夜视频免费| 成人免费视频91| 色棕色天天综合网| 国产精品欧美一区二区三区不卡 | 影视亚洲一区二区三区| 亚洲aaa激情| 国产欧洲在线| 尤物九九久久国产精品的分类| 一本大道伊人av久久综合| 一二三四区精品视频| 不卡一区二区在线观看| 亚洲精品国产拍免费91在线| 精品人妻一区二区三区日产| 亚洲一级在线| 亚洲精品一区二| 在线观看视频一区二区三区 | 五月天av在线| 色爱精品视频一区| 蜜桃视频久久一区免费观看入口| 欧美性猛交xxxx免费看| 色老板免费视频| 久久这里都是精品| 天堂av手机在线| 蜜桃视频一区| 女人色极品影院| 欧美日韩激情在线一区二区三区| eeuss一区二区三区| 成人看片网站| 国a精品视频大全| 美女国产在线| 亚洲午夜精品视频| 国模无码一区二区三区| 欧美三级三级三级| 日韩 欧美 综合| 亚洲乱码国产乱码精品精98午夜 | 亚洲一区二区三区四区五区中文| 麻豆精品免费视频| 国产成人精品免费一区二区| 免费看黄色一级大片| 亚洲午夜激情在线| 一区二区视频在线观看| 综合亚洲色图| 国产精品精品软件视频| av一级久久| 国产精自产拍久久久久久| 中老年在线免费视频| 欧美理论片在线观看| 香蕉视频免费在线播放| 亚洲视频在线观看| 香蕉国产在线视频| 日韩免费一区二区三区在线播放| 亚洲天堂网在线视频| 日韩欧美亚洲一二三区| 日韩特黄一级片| 亚洲一区二区三区美女| 亚洲视频重口味| 国产午夜精品福利| 一女三黑人理论片在线| 成人激情视频网站| 久久久久久久久久久久国产精品| 久草中文综合在线| 美女网站免费观看视频| 亚洲一区久久| 男人操女人免费软件| 精品999网站| 欧美中日韩在线| 欧美日本亚洲韩国国产| 国产一二三四五| 影音先锋日韩在线| 最近免费观看高清韩国日本大全| 亚洲成人国产| 中国老女人av| 欧美日韩免费| 青青青在线视频播放| 在线观看视频免费一区二区三区| 国产一区二区三区小说| 亚洲经典自拍| 动漫av网站免费观看| 久久久水蜜桃av免费网站| 六月丁香婷婷在线| 久久免费国产| 性生活免费在线观看| 狠狠色综合日日| 韩国三级丰满少妇高潮| 国产精品一区二区黑丝| 中文字幕第九页| 91欧美激情一区二区三区成人| 蜜桃传媒一区二区亚洲av| 国产女人18水真多18精品一级做| 国产又粗又硬视频| 亚洲人123区| 日本系列第一页| 欧美中文字幕一区| va视频在线观看| 亚洲国产精品va在线看黑人动漫| 日本v片在线免费观看| 在线观看日韩欧美| 超碰在线观看免费版| 91黄色8090| 99久久综合国产精品二区| 91免费视频国产| 精品国产一区二区三区成人影院| 欧美不卡福利| 欧美激情电影| 亚洲精品蜜桃久久久久久| 美女精品在线观看| 奇米视频7777| 99国产精品国产精品毛片| 国产又粗又黄又猛| 一区二区三区日韩精品| 久久黄色精品视频| 日韩一级在线观看| 青青九九免费视频在线| 精品国产拍在线观看| 国产三级伦理在线| 国产精品久久久久久av福利| 欧美片网站免费| 欧美黑人3p| 亚洲视频日本| 亚洲一级片网站| 99在线热播精品免费| 精品人体无码一区二区三区| 亚洲一区二区综合| 波多野结衣电影在线播放| 欧美成人r级一区二区三区| 国产理论电影在线观看| 欧美国产精品日韩| 激情中国色综合| 久久99精品久久久久久久青青日本 | 久久成人羞羞网站| 中文字幕5566| 亚洲综合色网站| 一区二区三区在线免费观看视频| 亚洲精品一线二线三线无人区| 1024免费在线视频| 欧美一区深夜视频| 97一区二区国产好的精华液| 亚洲国产精品毛片| 日韩视频在线一区二区三区 | 草草草视频在线观看| 麻豆专区一区二区三区四区五区| 亚洲av成人无码一二三在线观看| 亚洲三级免费观看| 在线免费一区二区| 亚洲欧洲日产国产网站| av男人的天堂在线观看| 亚洲影院在线看| 欧美aaaa视频| 人人干人人干人人| 国产性天天综合网|