اگر به سایت
stackoverflow دقت کنید، اندازه textarea ایی که کاربران امکان ارسال مطلب دارند، قابل تغییر است:
شاید برای شما جالب باشد که بدانید به چه صورتی اینکار را انجام دادهاند. اینکار با استفاده از افزونه
TextArea Resizer صورت گرفته است. (
دریافت کتابخانه به همراه مثال)
البته حالت عمومیتری نیز توسط jQuery-UI استاندارد پشتیبانی میشود (امکان تغییر اندازه یک المان با قابلیت تغییر اندازه در حالت کلی). برای مثال به صفحهی سادهی ASP.Net زیر دقت بفرمائید:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm5.aspx.cs" Inherits="testWebForms87.WebForm5" %>
<!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 runat="server">
<title></title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js" type="text/javascript"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.5.3/jquery-ui.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(function() {
$("#resizableArea").resizable({
handles: "s"
})
.find("textarea").height("100%").width("100%");
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="resizableArea" style="width:300px; height:200px" >
<asp:TextBox ID="TextBox1" runat="server" TextMode="MultiLine" ></asp:TextBox>
</div>
</form>
</body>
</html>
در اینجا با استفاده از jQuery-UI ابتدا div ایی با id مساوی resizableArea پیدا میشود و تابع resizable به آن اعمال میگردد. سپس در این div ، تمامی عناصر textarea موجود یافت شده و طول و عرض آنها به اندازهی جدید تغییر یافته div تنظیم خواهد شد. در مورد تنظیمهای دیگری مانند نمایش ناحیه تغییر یافته به صورت animation میتوان به
راهنمای آن مراجعه نمود.
برای مثال با استفاده از این روش میتوان یک GridView با قابلیت تغییر اندازه ایجاد کرد و امثال آن. یا برای نمونه شاید با مثالهایی که به گرید نمایش داده شده اسکرول بار اضافه میکنند برخورده باشید:
<div id="resizableArea" style="overflow:auto;height:200px;">
My Grid view ...
</div>
و یا استفاده از یک پنل:
<asp:Panel ID="pnlScroll" runat="server" Width="391px" Height="282px" ScrollBars="Vertical">
My Grid view ...
</asp:Panel>
با استفاده از روش عمومی فوق، میتوان به این div امکان تغییر اندازه را نیز اضافه کرد و آنرا از حالت غیرقابل تغییر بودن خارج نمود.