@ 功能 JS 实现原理详解

JavaScript023

@ 功能 JS 实现原理详解,第1张

来源于:Web前端开发之@ 功能 JS 实现原理详解 http://www.javashuo.com/article/p-bcfyqyay-y.html

1.取以前保留先来的信息

2.删除 @ 符号

3.生成需要显示的内容,一个 span

4.将生成内容打包放在 Fragment 中

5.将 Fragment 中的内容放入 range 中,并将光标放在空格之后

6.成功选人后让输入框获取焦点

1.按下了@键,保存按下@时的光标信息

2.获取当前文本。 有@时,获取@参数,展示@列表;没有有@时,纯文本展示。

1.光标点击时,@列表不展示

2.按下键盘时触发,

1.按下enter键发送

2.按下@键保存变量为true,执行后续操作;

3.按下删除键,删除@xx整体

a :因为在建立时默认会在 @xxx 后添加一个空格,

因此当得知光标位于 @xxx 以后的一个第一个字符后并按下删除按钮时,

应该将光标前的 @xxx 给删除

b :当光标位于 @xxx 中间时,按下删除按钮时应该将整个 @xxx 给删除。

js是javascript ,JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。

它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。

JavaScript是一种属于网络的脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果。

JavaScript脚本功能:

通常JavaScript脚本是通过嵌入在HTML中来实现自身的功能的。

1、是一种解释性脚本语言(代码不进行预编译)。

2、主要用来向HTML(标准通用标记语言下的一个应用)页面添加交互行为。

3、可以直接嵌入HTML页面,但写成单独的js文件有利于结构和行为的分离。

4、跨平台特性,在绝大多数浏览器的支持下,可以在多种平台下运行(如Windows、Linux、Mac、Android、iOS等)。

复制是一个使用频率特别高的操作,在网页中,一般可以选中要复制的内容,使用快捷键ctrl+c 将内容复制到剪贴板。除了使用系统提供的快捷方式复制网页内容,我们还可以用JS实现复制,这得益于document的execCommand('copy') 命令。

我们可以通过表单元素的select()方法选中内容,表单元素因为textarea限制少于input,所以推荐使用textarea。我们可以动态创建一个textarea元素,将textarea的value属性值设置为上面的innerText属性值,再执行textarea的select方法选中。

上面实现了选中,下面就可以实现复制功能了。

最后一步就可以用execCommand('copy')实现复制了,它可以复制浏览器中选中的文本,比如说上面被textarea选中的文本,复制之后记得移除textarea。

第二步和第三步可以优化一下,创建一个copy函数,函数参数设置为第一步需要复制的文本,返回值为复制的结果。

完整JS示例如下:

使用示例

可以将上面的完整JS示例写入一个JS文件,将JS文件引入HTML中,通过JS点击事件来执行复制函数。