Skip to content
You are here: خانه arrow ترفندها arrow Javascript Hacks arrow fix ie hover

fix ie hover چاپ ايميل
امتياز: / 7
ضعيفعالي 

حتما شما هم توجه شديد كه همه مرورگرهاي دنيا براي تغيير رنگ يك كنترل هنگام قرار گرفتن موس روي اون از خاصيت hover كه در مشخصات CSS قرار ميگيره پشتيباني ميكنند به غير از ...

خوب ديگه هميشه اوني كه گند ميزنه به همه چيز چيه : IE
خوب مفهوم نوشته هاي بالا چيه ؟
اين بدين معناست كه شما وقتي بخواهيد با رد شدن موس از روي يك سطر از جدول رنگ اون تغيير كنه و بعدش دوباره به رنگ قبليش برگرده در همه ي مرورگرها ميتونيد فقط از اين استفاده كنيد :

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html;
charset=utf-8" />
<title>Untitled Document</title>
 
 
<style type="text/css">
<!--
 
.nav:hover,
.hover {
    background-color: #BBC5EC;
}
 
table tr.nav:hover th,
table tr.hover th {
    background-color: #999999;
}
-->
</style>
</head>
 
<body>
<table border="1">
 <tr class="nav">
   <td onclick="">1111</td>
    <td>111</td>
    <td>111</td>
    <td>111</td>
  </tr>
  <tr class="nav">
   <td>222</td>
    <td>222</td>
    <td>222</td>
    <td>222</td>
  </tr>
  <tr class="nav">
   <td>333</td>
    <td>333</td>
    <td>333</td>
    <td>333</td>
  </tr>
</table>
</body>
</html>
 
اما ميشه اين كد رو براي هماهنگ بودن با همه ي مرورگرها دستكاري نكرد و عوضش يه تيكه كد جاوا اسكريپت براي ايجاد هماهنگي نوشت

كد قبلي رو بدون تغيير قسمت HTML و حتي CSS تكرار ميكنيم و فقط با كمك جاوااسكريپت مشكل در IE رو حل ميكنيم :


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type="text/javascript" language="javascript">
function ieHover() 
{
    var rows = document.getElementsByTagName('tr');
    for ( var i = 0; i < rows.length; i++ ) 
  {
        if ( navigator.appName == 'Microsoft Internet Explorer' ) 
    {
            rows[i].onmouseover = function() 
      {
                this.className += ' hover';
            }
            rows[i].onmouseout = function() 
      {
                this.className = this.className.replace( ' hover', '' );
            }
        }
    }
}
window.onload=ieHover;
</script>
 
<style type="text/css">
<!--
 
.nav:hover,
.hover {
    background-color: #BBC5EC;
}
 
table tr.nav:hover th,
table tr.hover th {
    background-color: #999999;
}
-->
</style>
</head>
 
<body>
<table border="1">
 <tr class="nav">
   <td onclick="">1111</td>
    <td>111</td>
    <td>111</td>
    <td>111</td>
  </tr>
  <tr class="nav">
   <td>222</td>
    <td>222</td>
    <td>222</td>
    <td>222</td>
  </tr>
  <tr class="nav">
   <td>333</td>
    <td>333</td>
    <td>333</td>
    <td>333</td>
  </tr>
</table>
</body>
</html>
 
 

برگزيدن اين صفحه (44) | نقل قول اين مطلب | بيننده: 1074

نظرات (1)
RSS نظرها
1. 22-12-2007 18:31
بسیار جالب بود ، کار مارو خیلی راحت می کنه. 
خیلی ممنون
مهمان
This e-mail address is being protected from spam bots, you need JavaScript enabled to view it

نوشتن نظر
نام:
ايميل:
صفحه اصلي:
عنوان:
BBCode:Web AddressEmail AddressBold TextItalic TextUnderlined TextQuoteCodeOpen ListList ItemClose List
نظر:



كد:* Code
من اين نظر را دوستانه جهت تماس ارسال ميكنم

Powered by AkoComment Tweaked Special Edition v.1.4.6
AkoComment © Copyright 2004 by Arthur Konze - www.mamboportal.com
All right reserved

 
قبل >
 

ورود اعضا






رمز عبورتان را فراموش كرده ايد؟
هنوز ثبت نام نكرده ايد? فرم ثبت نام

خبر خوان

كاربران آنلاين در سايت

حاضرین در سایت : 1 نفر مهمان