سلام
بنده از عمد قسمتاما وقتی آخر صفحه بزارم هنگامی که تگ ها لود شدند این خاصیت رو اضافه میکنه پس میتونه درست کار کنه.
$(document).ready(function())
رو حذف کردم و یک آزمایشی انجام دادم.
هنگامی که بنده کد جی کوئری رو آخرین قسمت صفحه قرار دادم،تغیرات اعمال میشه و اگر بالای تگ ها قرار دهم خیر.
من این طور حدس میزنم وقتی من کد رو بالای تگ ها و اول صفحه میزارم. چون قبل از لود شدن تگ ها کد اجرا میشه ، خاصیت class="marked" رو به تگ ها اضافه میکنه و اون موقع اصلا تگی وجود نداره! و بعد که تگ ها تازه لود شدند دیگر خاصیت class="marked" رو اضافه نمیکنه چون یک بار (همان ابتدا) کار رو انجام داده.
ایا درست فهیمدم یا دلیل دیگری دارد؟
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script src="jquery-2.1.1.min.js"></script>
<style>
.marked {
background-color:tomato;
border: dotted solid thick 1px;
}
</style>
<title>It's porpuse practical practice!</title>
<meta http-equiv="refresh" content="5" />
</head>
<script>
$(":button").addClass("marked");
</script>
<body>
<form>
<fieldset>
<input type="button" value="Input Button">
<input type="checkbox">
<input type="file" />
<input type="hidden" />
<input type="image">
<input type="password">
<input type="radio">
<input type="reset">
<input type="submit">
<input type="text">
<select>
<option>Option</option>
</select>
<textarea></textarea>
<button>Button</button>
</fieldset>
</form>
</body>
</html>