讓IE8瀏覽器支持function.bind()方法
來源:易賢網(wǎng) 閱讀:1715 次 日期:2014-10-17 11:22:18
溫馨提示:易賢網(wǎng)小編為您整理了“讓IE8瀏覽器支持function.bind()方法”,方便廣大網(wǎng)友查閱!

IE8支持function.bind()方法

?123456789101112131415161718192021 <script type="text/javascript"> if (!Function.prototype.bind) { Function.prototype.bind = function (oThis) { if (typeof this !== "function") { throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable"); } var aArgs = Array.prototype.slice.call(arguments, 1), fToBind = this, fNOP = function () {}, fBound = function () { return fToBind.apply(this instanceof fNOP && oThis ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments))); }; fNOP.prototype = this.prototype; fBound.prototype = new fNOP(); return fBound; }; } </script>

主要解決“百度地圖”官網(wǎng)上的例子的bug,摘取如下代碼:

?12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="initial-scale=1.0, user-scalable=no" /> <style type="text/css"> body, html {width: 100%;height: 100%;margin:0;font-family:"微軟雅黑";} #allmap{width:100%;height:500px;} p{margin-left:5px; font-size:14px;} </style> <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=39b92e64ae5622663ceceaccd8ab8eb1"></script> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <title>給多個點添加信息窗口</title> <script type="text/javascript"> if (!Function.prototype.bind) { Function.prototype.bind = function (oThis) { if (typeof this !== "function") { throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable"); } var aArgs = Array.prototype.slice.call(arguments, 1), fToBind = this, fNOP = function () {}, fBound = function () { return fToBind.apply(this instanceof fNOP && oThis ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments))); }; fNOP.prototype = this.prototype; fBound.prototype = new fNOP(); return fBound; }; } </script> </head> <body> <div id="allmap"></div> <p>點擊標注點,可查看由純文本構(gòu)成的簡單型信息窗口</p> </body> </html> <script type="text/javascript"> // 百度地圖API功能 map = new BMap.Map("allmap"); map.centerAndZoom(new BMap.Point(116.417854,39.921988), 15); var data_info = [[116.417854,39.921988,"地址:北京市東城區(qū)王府井大街88號樂天銀泰百貨八層"], [116.406605,39.921585,"地址:北京市東城區(qū)東華門大街"], [116.412222,39.912345,"地址:北京市東城區(qū)正義路甲5號"] ]; var opts = { width : 250, // 信息窗口寬度 height: 80, // 信息窗口高度 title : "信息窗口" , // 信息窗口標題 enableMessage:true//設(shè)置允許信息窗發(fā)送短息 }; for(var i=0;i<data_info.length;i++){ var marker = new BMap.Marker(new BMap.Point(data_info[i][0],data_info[i][1])); // 創(chuàng)建標注 var content = data_info[i][2]; map.addOverlay(marker); // 將標注添加到地圖中 marker.addEventListener("click",openInfo.bind(null,content)); } function openInfo(content,e){ var p = e.target; var point = new BMap.Point(p.getPosition().lng, p.getPosition().lat); var infoWindow = new BMap.InfoWindow(content,opts); // 創(chuàng)建信息窗口對象 map.openInfoWindow(infoWindow,point); //開啟信息窗口 } </script>

更多信息請查看IT技術(shù)專欄

更多信息請查看腳本欄目
易賢網(wǎng)手機網(wǎng)站地址:讓IE8瀏覽器支持function.bind()方法

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)