كدنويسی جاوا اسكريپ و جی كوئری : مثال‌ها و بهترين شيوه‌ها

مثال‌ها و بهترين شيوه‌ های استاندارد كدنويسي جاوا اسكريپ و جی كوئری


سوران خضری 22 دیدگاه JQuery , استاندارد وب سایت Monday, 16th January , 2012 66728 بازدید

هنگامي كه جي كوئری به درستي مورد استفاده قرار گيرد، مي‌تواند براي داشتن سايت‌هاي تعاملي، جالب و مهيج مفيد واقع شود. اين نوشته تعدادي از بهترين تمرين‌ها و مثال‌ها را براي استفاده از فريم ورک محبوب جاوا اسكريپت براي ايجاد اثرهاي نامحسوس (unobtrusive) و در دسترس اسكريپتي DOM (Document Object Mode) در بر مي‌گيرد. اين نوشته نشان خواهد داد چه تركيب‌هايي بهترين شیوه‌ها نسبت به جاوا اسكريپت هستند و علاوه بر آن چرا جي كوئري يك فريم ورک انتخابي خوب براي پياده‌سازي بهترين شيوه‌ها است.


webtarget.ir JQuery


1) چرا جي كوئري ؟

جي كوئری ايده‌آل است چون مي‌تواند انيميشن‌ها و تعاملات (interactions) موثري را ايجاد نمايد. جي كوئري براي فهميدن، ساده و براي استفاده كردن، راحت است به اين معني كه منحني يادگيري آن كوچك در حاليكه امكانات آن (تقريباً) بي نهايت است.

جاوا اسكريپت و بهترين شيوه‌ها

جاوا اسكريپت براي مدت طولاني موضوع بحث‌هاي داغ زيادي است در مورد اينكه آيا امكان استفاده از آن وجود دارد در حاليكه هنوز به بهترين شيوه‌هاي دستيابي و برآوردن استانداردها وفادار مانده است.

پاسخ به اين سوال هنوز داده نشده، با اين حال ظهور فريم ورك‌هاي جاوا اسكريپت مثل جي كوئري ابزارهاي لازم براي ايجاد وب سايت‌هاي زيبا بدون نگراني در مورد مسائل دسترس‌پذيري را فراهم آورده است.

بديهي است مسائلي وجود دارد كه راه‌حل جاوا اسكريپت بهترين گزينه نيست. قاعده كلي در اينجا اين است: از اسكريپت نويسي DOM براي افزايش عملكرد استفاده كنید ، نه براي ايجاد آن.

اسكريپت نويسي DOM نامحسوس

در حاليكه اصطلاح “اسكريپت نويسي DOM” واقعاً فقط به استفاده از اسكريپت‌ها (در اين مورد، جاوا اسكريپت‌ها) براي دسترسي به مدل شي سند (Document Object Mode) اشاره دارد، به صورت گسترده‌اي به عنوان راهي براي توصيف آنچه كه واقعاً بايد ” اسكريپت نويسي DOM نامحسوس” (unobtrusive DOM scripting) ناميده شود، تبديل شده است. در واقع هنر افزودن جاوا اسكريپت به صفحه، در اين روش اين است كه اگر جاوا اسكريپت هم وجود نداشت صفحه هنوز هم به درستی نمایش داده شود (يا حداقل تنزل كمتري داشته باشد). در دنياي وب ، اسكريپت نويسي DOM با استفاده از جاوا اسكريپت انجام مي‌شود.

نتيجه: دسترس پذيري و تجزيه محتوا

هدف هر توليد كننده، طراح يا برنامه نويس وب، ايجاد محتوايي است كه توسط طيف وسيعي از مخاطبان قابل دسترس باشد. با اين حال اين كار بايد با دقت در طراحي، قابليت تعامل و ظاهر سايت به تعادل برسد. با استفاده از نظريه هاي مطرح شده در اين نوشته، طراحان، برنامه نويسان و توليد كنندگان وب، دانش و درك استفاده از جي كوئري براي اسكريپت نويسي DOM براي دسترسي و تجزيه را خواهند داشت.


2) اسكريپت نويسي DOM نامحسوس؟

در يك دنياي ايده آل، وب سايت‌ها قابليت‌ها و افكت‌هاي پويايي دارند كه به خوبي تجزيه شده‌اند. اين به چه معناست؟ اين به معني پيدا كردن راهي شامل يك ويجت متحرك كشويي (sliding) براي نمايش اخبار در يك صفحه وب است كه با جاوا اسكريپت وب2 به طرز جالبي انيميت (animate) شده است، در حاليكه هنوز مي‌توان مطمئن بود كه همان اخبار به درستي نشان داده مي‌شوند اگر جاوا اسكريپت در مرورگر كاربر پشتيباني نشده يا غير فعال شده باشد.

تئوري پشت اين تكنيك بسيار ساده است: هدف نهايي اين است كه جاوا اسكريپت براي شيوه عمل عناصر يك صفحه به كار گرفته شود. جاوا اسكريپت براي افزودن و بهبود افكت‌ها و تعاملات مورد استفاده قرار مي‌گيرد. قواعد اصلي براي اسكريپت نويسي DOM‌ در زير مي‌آيند.

قاعده شماره 1: كاركرد جداگانه جاوا اسكريپت

قابليت‌هاي جاوا اسكريپت را در يك لايه رفتاري، مجزا كنيد به طوريكه جدا و مستقل از (X)HTML و CSS‌ باشد. (X)HTML لايه نشانه گذاري، CSS لايه نمايش و جاوا اسكريپت لايه رفتاري است. اين به معناي ذخيره كردن تمام كدهاي جاوا اسكريپت در يك فايل خارجي و ايجاد صفحاتي است كه به قابل استفاده بودن جاوا اسكريپت اعتماد نمي‌كنند.

تكه كد زير را نگاه كنيد:

نشانه گذاري بد:

هرگز event هاي جاوا اسكريپت را به عنوان ويژگي‌هاي درون خطي (inline) بكار نگيريد. اين عمل را بايد به طور كامل از ذهن خود پاك كنيد.

<a  href="#"  onclick="doSomething()">Click! </a>

نشانه گذاري خوب:

همه رفتارهاي جاوا اسكريپت بايد در فايل اسكريپت خارجي گنجانده شده و با تگ <script> در قسمت head‌ صفحه به سند لينك شوند. بنابراين تگ بالا به شكل زير در مي‌آيد:

 <a href="backuplink.html" class="doSomething">Click!</a>

و كد جاوا اسكريپت در داخل فايل myscript.js (يك اسم فرضي) مي‌تواند چيزي شبيه اين باشد:

$('a.doSomething').click(function(){
    // Do something here!
    alert('You did something, woo hoo!');
});

متد click() در جي كوئري به ما اجازه مي‌دهد تا براحتي يك event كليك را به نتيجه(ها) انتخابگرمان نسبت دهيم. بنابراين كد بالا همه تگ‌هاي <a> از كلاس doSomething را انتخاب مي‌كند و يك رويداد كليك را كه يك تابع را فراخواني مي‌كند به آنها نسبت مي‌دهد.

قاعده شماره 2: هرگز به جاوا اسكريپت وابسته نشو

براي اينكه بدرستي جاوا اسكريپت نامحسوس پياده سازي شود، برنامه نويس هرگز نبايد بر پشتيباني جاوا اسكريپت براي ارائه محتوا يا اطلاعات تكيه كند. استفاده از جاوا اسكريپت براي افزايش اطلاعات، آن را زيباتر و تعاملي‌تر مي‌كند اما هرگز فرض را بر اين نگذاريد كه جاوا اسكريپت در مرورگر كاربر فعال است. اين قاعده كلي مي‌تواند در واقع براي هر تكنولوژي طرف سوم (third-party) به كار برده شود مثل Flash يا Java.

اگر آن تكنولوژي در داخل هر مرورگر وبي وجود نداشته باشد (يا هميشه فعال نباشد)، آن وقت بايد اطمينان حاصل كنيد كه صفحه بدون آن هنوز بطور كامل در دسترس و قابل استفاده است.

نشانه گذاري بد:

تكه كد زير نشان مي‌دهد كه جاوا اسكريپت ممكن است براي نمايش پيغام “Good Morning” (يا “Good Afternoon”) در يك بسته به زمان روز، بكار برده شود. (بديهي است كه اين يك مثال ابتدايي است).

<script language="javascript">
var now = new Date();
if(now.getHours() < 12)
    document.write('Good Morning!');
else
    document.write('Good Afternoon!');
</script>

اين اسكريپت درون خطي نادرست است زيرا در صورتي كه جاوا اسكريپت در مرورگر مورد نظر غير فعال باشد هيچ چيزي نمايش داده نمي‌شود. اين خوشايند نيست. كاربري كه جاوا اسكريپت ندارد پيغام خوشامدگويي ما را از دست داده است.

نشانه گذاري خوب:

راه حل درست و قابل دسترس براي پياده سازي اين بايد بسيار ساده‌تر و خواناتر باشد. مثل:

<p title="Good Day Message">Good Morning!</p>

به وسيله ويژگي “title” اين پاراگراف مي‌تواند با يك انتخابگر جي كوئری انتخاب شود. همانند تكه كد زير:

var now = new Date();
if(now.getHours() >= 12)
{
    var goodDay = $('p[title="Good Day Message"]');
    goodDay.text('Good Afternoon!');
}

زيبايي اين تكه كد اين است كه همه جاوا اسكريپت در يك اسكريپت خارجي (external) قرار گرفته و صفحه همانند يك (X)HTML استاندارد رندر مي‌شود كه بدين معناست كه اگر جاوا اسكريپت اجرا نشود، صفحه هنور بطور 100%، (X)HTML خالص است. تنها مشكل اين است كه در بعدازظهر صفحه هنوز پيام صبح بخير را نشان مي‌دهد. به هر حال اين مي‌تواند به عنوان يك تنزلِ درجه قابل پذيرش ديده شود.

قاعده شماره 3: نشانه گذاري معنايي و قابل دسترس در ابتدا بيايد

بسيار مهم است كه نشانه گذاري (X)HTML ساختاري معنايي داشته باشد. قاعده كلي اينجا اين است كه اگر نشانه گذاري (markup) صفحه ساختاري معنايي داشته باشد، بايد براي طيف وسيعي از دستگاه ها (device) قابل دسترسي باشد.

نشانه گذاري معنايي براي اسكريپت نويسي DOM نامحسوس مهم است زيرا مسير برنامه نويس را براي ايجاد اثر اسكريپت نويسي DOM شكل خواهد داد. اولين گام براي ايجاد هر صفحه‌اي كه با جي كوئري قابليت‌هايي را به آن اضافه مي‌كنيد اين است كه نشانه‌گذاري آن نوشته شود و مطمئن شويد كه آن نشانه گذاري ساختاري معنايي دارد. با دستيابي به اين امر، برنامه نويس مي‌تواند جي كوئري را براي تعامل با نشانه گذاري صحيح معنايي بكار بگيرد (آنچه باقي مي‌ماند يك سند (X)HTML تميز و خوانا و جدا از لايه رفتاري است).

نشانه گذاري خيلي بد:

تكه كد زير ليستي از آيتم‌ها و توضيحات را با روشي كه بطور وحشتناكي غير معنايي است (unsemantic)، نشان مي‌دهد.

<table>
    <tr>
        <td onclick="doSomething();">First Option</td>
        <td>First option description</td>
    </tr>
    <tr>
        <td onclick="doSomething();">Second Option</td>
        <td>Second option description</td>
    </tr>
</table>

نشانه گذاري بد:

تكه كد زير ليستي از آيتم‌ها و توضيحات را با روشي كه بيشتر معنايي است، نشان مي‌دهد. با اين حال جاوا اسكريپت inline باعث شده اين كد نيز كاملاً معنايي نباشد.

<dl>
    <dt onclick="doSomething();">First Option</dt>
    <dd>First option description</dd>
    <dt onclick="doSomething();">Second Option</dt>
    <dd>Second option description</dd>
</dl>

نشانه گذاري خوب:

اين تكه كد نشان مي‌دهد كه چگونه ليست بالا بايد نشانه گذاري شود. هر تعاملي با جاوا اسكريپت در متد load‌ جي كوئري قابل دستيابي خواهد بود و بطور موثري همه نشانه گذاري‌هاي رفتاري را از كدهاي (X)HTML حذف مي‌كند.

<dl id="OptionList">
    <dt>First Option</dt>
    <dd>First option description</dd>
    <dt>Second Option</dt>
    <dd>Second option description</dd>
</dl>

id=”OptionList” این توانایی را به برنامه نویس خواهد داد تا با استفاده از سلكتورهاي جي كوئري به ليست بالا دسترسي داشته باشيم.


3) درك جي كوئري براي اسكريپت نويسي DOM نامحسوس

اين بخش 3 نكته با ارزش از جي كوئري را براي پياده سازي بهترين شيوه‌ها و افكت‌هاي قابل دسترس ارائه مي‌كند.

درك انتخابگرها: ستون فقرات jQuery

اولين گام براي اسكريپت نويسي DOM نامحسوس (حداقل در jQuery و Prototype) بكارگيري انتخابگرها (selectors) است. انتخابگرها به طرز شگفت آوري مي‌توانند يك عنصر را از درخت DOM انتخاب كنند بطوريكه آن عنصر از چند طريق قابل دستكاري باشد.

اگر شما با CSS آشنا باشد پس مي‌توانيد انتخابگرهاي جي كوئري را درك كنيد. آنها تقريباً همان انتخابگرهاي CSS هستند و تقريباً به همان نحو مورد استفاده قرار مي‌گيرند.

جي كوئري يك تابع كاربردي مخصوص براي انتخاب عناصر تدارك ديده است كه $ نام دارد.

مثال‌هاي خيلي ساده‌اي از انتخابگرهاي جي كوئري:

  • $(document) // Activate jQuery for object
  • $(‘#mydiv’) // Element with ID “mydiv”
  • $(‘p.first’) // P tags with class first.
  • $(‘p[title=”Hello”]’) // P tags with title “Hello”
  • $(‘p[title^=”H”]’) // P tags title starting with H
$(document)

اولين گزينه متدهاي كتابخانه جي كوئری را به يك شي DOM (در اين مورد، شي document) اعمال خواهد كرد.

$('#mydiv')

گزينه دوم هر تگ كه صفت id آن mydiv باشد را انتخاب خواهد كرد.

$('p.first')

گزينه سوم همه تگ‌هاي <p> را انتخاب خواهد كرد كه صفت class آنها برابر first‌ باشد.

$('p[title="Hello"]')

اين گزينه همه تگ‌هاي <p> را انتخاب خواهد كرد كه صفت title آنها برابر Hello باشد. تكنيك‌هايي مانند اين قادر به استفاده از نشانه گذاري معنايي صحيح (X)HTML مي‌باشند در حاليكه هنوز تسهيلات اسكريپت نويسي DOM براي ايجاد فعل و انفعالات پيچيده‌تر مورد نياز است.

$('p[title^="H"]')

اين ما را قادر مي‌سازد تا همه تگ‌هاي <p>‌ را در صفحه كه صفت title آنها با حرف H شروع مي‌شود، انتخاب كنيم.

تقريباً هر چيزي كه شما بتوانيد با CSS3 انجام دهيد در جي كوئری كار خواهد كرد به علاوه بسياري انتخابگرهاي پيچيده ديگر.

ليست كاملي از انتخابگرهاي جي كوئري را مي‌توانيد در آدرس زير مشاهده كنيد:

http://docs.jquery.com/Selectors

همچنين مشخصات انتخابگرهاي CSS3 را مي‌توانيد از سايت W3C از لينك زير مشاهده بفرماييد:

http://www.w3.org/TR/css3-selectors/

آماده شدن $(document).ready()

به طور سنتي رويداد (event)هاي جاوا اسكريپت به يك سند با استفاده از ويژگي onload در تگ body صفحه متصل مي‌شدند. آن را از ذهن خود پاك كنيد.جي كوئری براي ما يك تابع ويژه بر روي شي سند تدارك ديده كه ready خوانده مي‌شود و به ما اجازه اجراي كد را تنها بعد از آنكه بارگذاري (loading) DOM به طور كامل به پايان رسيده باشد، مي‌دهد. اين كليد اسكريپت نويسي DOM نامحسوس است. اين به ما اجازه مي‌دهد تا به طور كامل كد جاوا اسكريپت را از نشانه گذاري (markup) جدا كنيم. با استفاده از $(document).ready() ما مي‌توانيم يك سري از رويدادها را صف بندي (queue) كنيم و آنها پس از آنكه DOM مقداردهي اوليه شد اجرا شوند.

اين بدان معنيست كه ما مي‌توانيم افكت‌هاي كاملي را براي صفحه‌هايمان ايجاد كنيم بدون تغيير نشانه گذاري براي عناصر مورد بحث.براي نشان دادن زيبايي اين قابليت، اجازه دهيد يك كادر هشدار (alert box) كه پيغام Hello World!‌ را نمايش مي‌دهد با جاوا اسكريپت ايجاد نماييم.نشانه گذاري زير نشان مي‌دهد كه بدون جي كوئری ممكن است چگونه ما يك پيغام Hello World! را به نمايش در آوريم.

نشانه گذاري بد:

<script language="javascript">
alert('Hello World');
</script>

نشانه گذاري خوب:

استفاده از اين قابليت در جي كوئری ساده است. تكه كد زير نشان مي‌دهد كه ما چگونه ممكن است پس از آن كه سند ما بارگذاري شده باشد كادرهاي هشدار قديمي Hello World را فراخواني كنيم. زيبايي واقعي اين نشانه گذاري اين است كه در يك فايل خارجي جاوا اسكريپت قرار بگيرد. هيچ تاثيري بر روي صفحه (X)HTML وجود ندارد.

$(document).ready(function()
{
    alert('Hello World');
});

تابع $(document).ready() يك تابع را به عنوان آرگومان مي‌گيرد. (در اين مورد يك تابع بي نام (anonymous) ايجاد شده – یک تکنیک است که در سراسر مستندات jQuery استفاده می شود.) تابع پاس داده شده به $(document).ready() بعد از آن كه بارگذاري DOM به پايان رسيد فراخواني مي‌شود و كد داخل آن اجرا مي‌گردد. در مورد مثال ما تابع alert فراخواني مي‌شود.

ايجاد قانون CSS پويا

يك مشكل با بسياري از اثرات اسكريپت نويسي DOM اين است كه آن ها اغلب براي پنهان كردن عناصر سند از ديد، به ما نياز دارند. اين پنهان سازي معمولاً با استفاده از CSS به دست مي‌آيد. با اين حال اين كار كمتر مطلوب است. اگر مرورگر كاربر از جاوا اسكريپت پشتيباني نكند (يا جاوا اسكريپت غير فعال باشد) هنوز CSS پشتيباني مي‌شود پس عناصري كه ما با CSS پنهان كرده‌ايم هرگز ديده نخواهند شد، چون فعل و انفعالات جاوا اسكريپت ما اجرا نمي‌شده است.

راه حل اين كار در قالب پلاگيني براي جي كوئری كه cssRule ناميده مي‌شود، مي‌آيد كه به ما اجازه مي‌دهد تا ما با استفاد از جاوا اسكريپت به راحتي قوانين CSS را به شيوه نامه (style sheet) سند اضافه كنيم. اين بدان معناست كه ما مي‌توانيم عناصر صفحه را با استفاده از CSS پنهان كنيم هر چند كه CSS تنها در صورتي اجرا مي‌شود كه جاوا اسكريپت در حال اجرا باشد.

نشانه گذاري بد:

HTML:

<h2>This is a heading</h2>
<p class="hide-me-first">
This is some information about the heading.
</p>

CSS:

p.hide-me-first
{
    display: none;
}

با فرض اينكه يك پاراگراف با صفت class برابر با hide-me-first براي اولين بار توسط CSS پنهان و سپس توسط جاوا اسكريپت بعد از يك سري تعاملات با كاربر در آينده نمايش داده مي‌شود، اگر جاوا اسكريپت هيچ وقت اجرا نشود محتواي اين پاراگراف هيچ وقت قابل ديدن نخواهد بود.

نشانه گذاري خوب:

HTML:

<h2>This is a heading</h2>
<p class="hide-me-first">
This is some information about the heading.
</p>
jQuery Javascript:
$(document).ready(function{
    jQuery.cssRule("p.hide-me-first", "display", "none");
});

استفاده از $(document).ready() در اينجا براي پنهان كردن پاراگراف بدين معنيست كه اگر جاوا اسكريپت غير فعال باشد پاراگراف هرگز پنهان نمي‌شود بنابراين محتواي پاراگراف هنوز در دسترس است. اين دليل اصلي براي ايجاد قوانين پوياي CSS مبتني بر جاوا اسكريپت است.


4) نتيجه

جي كوئری يك كتابخانه بسيار قوي است كه همه ابزارهاي مورد نياز براي ايجاد تعاملات زيبا و انيميشن‌ها در صفحات وب را فراهم آورده است كه به برنامه نويس قدرت لازم را براي انجام كارهاي مورد نياز خود مي‌دهد.

اين نوشته مطالب زير را پوشش داده است:

  • 1-چرا اسكريپت نويسي DOM نامحسوس براي دسترس پذيري اينقدر مهم است
  • 2-چرا جي كوئری يك انتخاب طبيعي براي پياده سازي اثرات اسكريپت نويسي DOM نامحسوس است
  • 3-انتخابگرهاي جي كوئری چگونه كار مي‌كنند
  • 4-چگونه قوانين CSS نامحسوس را در جي كوئری پياده سازي كنيم

نوشته‌اي كه پيش رو داشتيد ترجمه‌اي از يكي از مقالات سايت بسيار خوب sMashingMagazine بود كه در ترجمه آن سعي بر آن بود كه به اصل مقاله و لغات به كار رفته در آن وفادار مانده در عين حال مطلب ترجمه شده تا حد زيادي قابل فهم و روان باشد. ترجمه بعضي از مفاهيم همچون “اسكريپت نويسي DOM نامحسوس” رسا نيست و نمي‌تواند منظور نويسنده مطلب را به درستي نشان دهد كه براي اين كار ناچاراً بايد منظور نويسنده را در توضيحاتي كه مي‌دهد درك كنيم و اين سه كلمه نمي‌تواند آن مفهوم را برساند. براي اكثر لغات ترجمه شده اصل كلمه انگليسي آن در داخل پرانتز آمده است.

اميدوارم ترجمه اين مطلب مورد توجه عزيزان قرار بگيرد و با نظرات خوب و سازنده و همچنين بحث‌هايي كه در مورد اين نوشته مطرح مي‌فرماييد به رفع ابهام و پاسخ به سوالات عزيزاني كه در مورد اين مطلب نظرات خود را اينجا مطرح مي‌كنند كمك نماييد.


این مطلب توسط جناب آقای سوران خضری برای وب تارگت آماده شده است



نویسنده / مترجم : سوران خضری

برنامه نويس وب ، علاقه مند به PHP و jQuery ، گاهي هم اگه مطلب خوب ببينم ترجمه ميكنم


22 دیدگاه برای این نوشته ثبت شده است


  1. بابک
    17 January 2012

    سلام خیلی وقت منتظر پست بعدیتون بودم که باز هم با یک پست زیبا گل کاشتید.

    همیشه برقرار باشید




  2. امیر اخوان
    18 January 2012

    مرسی … جالب بود




  3. محسن
    31 January 2012

    سلام.

    اگر بتونید یک سری آموزش ها در مورد انواع تکنیک های jQuery که در سایتها استفاده میشه، به صورت سریالی توی وبلاگ قرار بدید، خیلی عالیه.

    مثلا انواع افکتهایی که با jQuery روی منوها اعمال میشه یا
    form validation با jQuery و نظیر اینها . . .




    • امیر سروری
      2 February 2012

      محسن @ سلام محسن جان امیدوارم خوب باشی . تو فکر این موضوع هستم چه کتم که دست تنهاییم و تهیه مطالب خوب هم زمان بر و سخت هست . با توجه به اینکه سعی داریم کیفیت به کمیت غلبه داشته باشه . همین مطلب هم دوست خوبمون سوران خضری ترجمه و ویرایش کرده که همینجا باز هم از ایشون تشکر میکنم و منتظر مطالب بعدی ایشون هم هستیم ;-)




  4. علی
    16 February 2012

    بسیار مقاله مناسبی بود . سپاس




  5. یوسف
    17 May 2012

    سلام.

    فکر می کنم اینجا اشتباهی صورت گرفته باشه:
    “گزینه دوم هر تگ که صفت id آن mydiv باشد را انتخاب خواهد کرد.”

    گزینه دوم: “$(‘#mydiv’) // Element with ID “mydiv””

    متشکرم.

    امروز با سایت شما آشنا شدم، یک سایت پر محتوا و مفید. متشکرم. موفق باشید.




  6. داوود
    18 December 2012

    بنظرم گزینه + و – به انتهای مقالات اضافه کنید که کسایی که خوششون میاد نخوان بخاطر یک عبارت متشکرم کامن بزارن.

    یه بار + رو فشار میدن و تمام.
    باور کنید خیلی از خواننده ها اصلا حوصله ندارن تشکر هم کنن.
    اینظوری مقالات پر طرفدار هم مشخص میشن.

    موفق تر باشید.




    • سوران خضری
      18 December 2012

      دوست عزيز ممنون از نظرتون
      منم با + و – موافقم كه بتوني به نظرات + يا – بدي و اميدوارم جناب سروري اينو به كامنت ها اضافه كنن
      ولي به نظرم نوشته خوبي كه ميخوني و ميبيني طرف براي تهيه يا ترجمش زحمت كشيده حداقل ارزش يك كامنت تشكر رو داشته باشه
      موفق باشيد




      • داوود
        18 December 2012

        بله حتما. اما نه یک یک جمله کوتاه.
        نظرات باید در جهت نقد و بررسی مقاله و یا پرسش سوالات ارسال شوند.
        خوب یا بد بودن با + و –
        ضمن اینکه رعایت نکردن این مورد در وب فارسی، شامل همه وبلاگ هاست نه فقط اینجا




  7. فرشته
    10 January 2013

    ترجمه خیلی روان و خوب بود؛ به نکات جالبی هم اشاره کرده بود. خیلی ممنون




    • سوران خضری
      10 January 2013

      ممنون از حسن توجهتون. خوشحالم كه براتون مفيد بوده




  8. سارا
    8 June 2013

    سلام
    ممنون خیلی عالی بود :)




    • سوران خضری
      10 June 2013

      سلام
      با سپاس از شما
      موفق باشيد




  9. maryam
    1 August 2013

    سلام .خیلی عالی بود .ممنون از وقتی که گذاشتی واسه این مطلب




  10. رها
    2 August 2013

    سلام
    ممنون از زحمات شما در گرداوری مطالب
    اگر ممکنه در مورد jqury هایی که واسه اسلاید شوها هستند و jquery بنام fanybox که وقتی روی عکسها با موس حرکت میکنیم به حالت ذره بین در میاد و بعد از کلکل هم عکس رو بزرگ میکنه و اینکه در اسلاید شوها چطور و از چه جی کوئری هایی استفاده کنیم بیشتر مطلب بذارین
    با تشکر وارزوی توفیق




  11. رضا
    3 September 2013

    جالب بود ممنون




  12. سینا
    11 April 2015

    عالی بود.
    خیلی از سایتهای ایرانی مخصوصا سایتهای دولتی باید کلا از نو کد
    نویسی بشن.




  13. فروشگاه اینترنتی لباس
    15 April 2015

    ممنونم سایتتون حرف نداره




  14. arman
    4 May 2015

    سلام. خسته نباشید
    بنده یه قالب html دارم که با صورت جی کوئری کار میکنه و آدرس منوهای اون به صورت پیش فرض مثلا اینطوریه :
    “l<a href="#!/page_GALLERY"
    مشکلم اون لینکی هست که به متن ما داده وقتی توی فایل html تغییرش میدم لینک از کار میافته. توی فایل های js هم گشتم
    ولی عبارتی با نام page_GALLERYپیدا نکردم تا ویرایشش کنم البته توی یکی از فایل های js با عبارت اول لینک یعنی
    #! برخورد کردم که وقتی اون رو هم تغییر میدم بازم لینک از کار میافته.
    مشکل کار کجاست؟ لطفا راهنماییم کنید ( اگه لازمه فایل های مربوط به قالب رو براتون بفرستم)




  15. هادی زارع
    30 July 2015

    سلام و خسته نباشید
    با عرض پوزش یک سوال داشتم
    من به تازگی شروع به کار با Jquery کردم و میخوام که jquery رو در یک فایل js فراخوانی کنم و بعد فایل JS و در صفحه Html معرفی کنم خواستم بدونم آیا این کار امکان عملی شدن داره اگه امکارن داره راهش و بهم بگید




  16. سعید
    22 October 2015

    ممنوخیلی مفید بود



دیدگاه خود را بنویسید





نشانی ایمیل شما منتشر نخواهد شد.

کامنت های شما بعد از تأیید توسط نویسنده وبلاگ، منتشر خواهند شد.

لطفا دیدگاهتان تا حد امکان مربوط به پست بالا باشد. اگر حرف دیگری دارید و یا قصد تماس با من را دارید، از فرم تماس استفاده کنید.

شما میتوانید با مراجعه به سایت گراواتار یک آواتار اختصاصی برای خود تعریف کنید، تا در کنار نام شما نمایش داده شود

برای قرار دادن کدهای نمونه می توانید از تگ های [php] ، [html] ، [css] و [js] استفاده کنید.
به عنوان مثال کدهای php را می توان به صورت زیر قرار داد:
[php] var $whoLoveIranians = "WebTarget!"; [/php]



کلیه حقوق مادی و معنوی برای وب سایت وب تارگت محفوظ است ©2024 وب‌تارگت

استفاده از مطالب وب سایت در سایر وب سایت‌ها و نشریات چاپی با ذکر منبع آزاد است.