电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Javascript文本框腳本實現方法解析

瀏覽:106日期:2023-10-09 17:22:57

在 HTML 中,有兩種方式來表現文本框:一種是使用<input>元素的單行文本框,另一種是使用 <textarea>的多行文本框。這兩個控件非常相似,而且多數時候的行為也差不多。不過,它們之間仍 然存在一些重要的區別。

相對而言,<textarea>元素則始終會呈現為一個多行文本框。要指定文本框的大小,可以使用 rows 和 cols 特性。其中,rows 特性指定的是文本框的字符行數,而 cols 特性指定的是文本框的字符列數 (類似于 <inpu> 元素的 size 特性)。與 <input> 元素不同, <textarea> 的初始值必須要放在 <textarea>和</textarea>之間。

選擇文本

上述兩種文本框都支持 select()方法,這個方法用于選擇文本框中的所有文本。在調用 select() 方法時,大多數瀏覽器(Opera 除外)都會將焦點設置到文本框中。這個方法不接受參數,可以在任何 時候被調用。

var textbox = document.forms[0].elements['textbox1']; textbox.select();

在文本框獲得焦點時選擇其所有文本,這是一種非常常見的做法,特別是在文本框包含默認值的時 候。因為這樣做可以讓用戶不必一個一個地刪除文本。

​選擇(select)事件

與 select()方法對應的,是一個 select 事件。在選擇了文本框中的文本時,就會觸發 select 事件。不過,到底什么時候觸發 select 事件,還會因瀏覽器而異。

取得選擇的文本

雖然通過 select 事件我們可以知道用戶什么時候選擇了文本,但仍然不知道用戶選擇了什么文本。HTML5 通過一些擴展方案解決了這個問題,以便更順利地取得選擇的文本。該規范采取的辦法是添加 兩個屬性:selectionStart 和 selectionEnd。這兩個屬性中保存的是基于 0 的數值,表示所選擇 文本的范圍(即文本選區開頭和結尾的偏移量)。因此,要取得用戶在文本框中選擇的文本,可以使用 如下代碼。

function getSelectedText(textbox){ return textbox.value.substring(textbox.selectionStart, textbox.selectionEnd);}

IE8 及更早的版本中有一個 document.selection 對象,其中保存著用戶在整個文檔范圍內選擇 的文本信息;兼容IE8的寫法

function getSelectedText(textbox){ if (typeof textbox.selectionStart == 'number'){ return textbox.value.substring(textbox.selectionStart, textbox.selectionEnd); } else if (document.selection){ return document.selection.createRange().text; } }

選擇部分文本

現在除 select()方法之外,所有文本框都有一個 setSelectionRange() 方法。這個方法接收兩個參數:要選擇的第一個字符的索引和要選擇的最后一個字符之后的字符的索引 (類似于 substring()方法的兩個參數)。

textbox.value = 'Hello world!'//選擇所有文本 textbox.setSelectionRange(0, textbox.value.length); //'Hello world!'//選擇前 3 個字符 textbox.setSelectionRange(0, 3); //'Hel'//選擇第 4 到第 6 個字符 textbox.setSelectionRange(4, 7); //'o w'

E8 及更早版本支持使用范圍選擇部分文本。要選擇文本框中的部分文本,必須 首先使用 IE 在所有文本框上提供的 createTextRange()方法創建一個范圍,并將其放在恰當的位置 上。然后,再使用 moveStart()和 moveEnd()這兩個范圍方法將范圍移動到位。不過,在調用這兩個 方法以前,還必須使用 collapse()將范圍折疊到文本框的開始位置。此時,moveStart()將范圍的起 點和終點移動到了相同的位置,只要再給 moveEnd()傳入要選擇的字符總數即可。最后一步,就是使 用范圍的 select()方法選擇文本,如下面的例子所示。

textbox.value = 'Hello world!';var range = textbox.createTextRange();//選擇所有文本 'Hello world!'range.collapse(true); range.moveStart('character', 0); range.moveEnd('character', textbox.value.length); range.select();​//選擇前 3 個字符 'Hel'range.collapse(true); range.moveStart('character', 0); range.moveEnd('character', 3); range.select();​//選擇第 4 到第 6 個字符 'o w'range.collapse(true); range.moveStart('character', 4); range.moveEnd('character', 3); range.select();

兼容IE8的寫法

function selectText(textbox, startIndex, stopIndex){ if (textbox.setSelectionRange){ textbox.setSelectionRange(startIndex, stopIndex); } else if (textbox.createTextRange){ var range = textbox.createTextRange(); range.collapse(true); range.moveStart('character', startIndex); range.moveEnd('character', stopIndex - startIndex); range.select(); } textbox.focus();}

操作剪貼板

IE 是第一個支持與剪貼板相關事件,以及通過 JavaScript 訪問剪貼板數據的瀏覽器。HTML 5 后來也把剪貼板事件納入了規范。

beforecopy:在發生復制操作前觸發 。 copy:在發生復制操作時觸發。 beforecut:在發生剪切操作前觸發。 cut:在發生剪切操作時觸發。 beforepaste:在發生粘貼操作前觸發。 paste:在發生粘貼操作時觸發。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 钢化玻璃膜|手机钢化膜|钢化膜厂家|手机保护膜-【东莞市大象电子科技有限公司】 | 聚合氯化铝-碱式氯化铝-聚合硫酸铁-聚氯化铝铁生产厂家多少钱一吨-聚丙烯酰胺价格_河南浩博净水材料有限公司 | ET3000双钳形接地电阻测试仪_ZSR10A直流_SXJS-IV智能_SX-9000全自动油介质损耗测试仪-上海康登 | 建筑消防设施检测系统检测箱-电梯**检测仪器箱-北京宇成伟业科技有限责任公司 | 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 挨踢网-大家的导航!| 砂石生产线_石料生产线设备_制砂生产线设备价格_生产厂家-河南中誉鼎力智能装备有限公司 | STRO|DTRO-STRO反渗透膜(科普)_碟滤 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | DAIKIN电磁阀-意大利ATOS电磁阀-上海乾拓贸易有限公司 | 三氯异氰尿酸-二氯-三氯-二氯异氰尿酸钠-优氯净-强氯精-消毒片-济南中北_优氯净厂家 | 上海APP开发-APP制作-APP定制开发-上海APP开发制作公司-咏熠科技 | 净化车间_洁净厂房_净化公司_净化厂房_无尘室工程_洁净工程装修|改造|施工-深圳净化公司 | 上海冠顶工业设备有限公司-隧道炉,烘箱,UV固化机,涂装设备,高温炉,工业机器人生产厂家 | 【365公司转让网】公司求购|转让|资质买卖_股权转让交易平台 | 胶水,胶粘剂,AB胶,环氧胶,UV胶水,高温胶,快干胶,密封胶,结构胶,电子胶,厌氧胶,高温胶水,电子胶水-东莞聚力-聚厉胶粘 | 山东石英砂过滤器,除氟过滤器「价格低」-淄博胜达水处理 | 热回收盐水机组-反应釜冷水机组-高低温冷水机组-北京蓝海神骏科技有限公司 | 仿真茅草_人造茅草瓦价格_仿真茅草厂家_仿真茅草供应-深圳市科佰工贸有限公司 | 成人纸尿裤,成人尿不湿,成人护理垫-山东康舜日用品有限公司 | 小型手持气象站-空气负氧离子监测站-多要素微气象传感器-山东天合环境科技有限公司 | 耐驰泵阀管件制造-耐驰泵阀科技(天津)有限公司 | 光泽度计_测量显微镜_苏州压力仪_苏州扭力板手维修-苏州日升精密仪器有限公司 | 生鲜配送系统-蔬菜食材配送管理系统-连锁餐饮订货配送软件-挪挪生鲜供应链管理软件 | 河南橡胶接头厂家,河南波纹补偿器厂家,河南可曲挠橡胶软连接,河南套筒补偿器厂家-河南正大阀门 | 次氯酸钠厂家,涉水级次氯酸钠,三氯化铁生产厂家-淄博吉灿化工 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 植筋胶-粘钢胶-碳纤维布-碳纤维板-环氧砂浆-加固材料生产厂家-上海巧力建筑科技有限公司 | 不锈钢复合板|钛复合板|金属复合板|南钢集团安徽金元素复合材料有限公司-官网 | 广州办公室设计,办公室装修,写字楼设计,办公室装修公司_德科 | 福兰德PVC地板|PVC塑胶地板|PVC运动地板|PVC商用地板-中国弹性地板系统专业解决方案领先供应商! 福建成考网-福建成人高考网 | 智能终端_RTU_dcm_北斗星空自动化科技 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | 沈阳真空机_沈阳真空包装机_沈阳大米真空包装机-沈阳海鹞真空包装机械有限公司 | 哈希PC1R1A,哈希CA9300,哈希SC4500-上海鑫嵩实业有限公司 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | wika威卡压力表-wika压力变送器-德国wika代理-威卡总代-北京博朗宁科技 | 温州在线网|