js中substr函数,js 数组方法
大家好,如果您还对js中substr函数不太了解,没有关系,今天就由本站为大家分享js中substr函数的知识,包括js 数组方法的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!
javascript如何使用
1、字符串的创建
创建一个字符串有几种方法。最简单的是用引号将一组字符包含起来,可以将其赋值给一个字符串变量。
var myStr="Hello, String!";
我们在上面脚本创建了字符串,但本质上,它们并不是真正的字符串对象,准确地说,它们是字符串类型的值。要创建一个字符串对象,可使用如下语句:var strObj= new String("Hello, String!");
使用typeof运算符查看会发现,上面的myStr类型为string,而strObj类型为object。
如果想知道字符串的长度,使用其length属性:string.length。
得到字符串的指定位置的字符使用方法:string.charAt(index);
2、字符串的拼接
非常简单,就用一个"+"将两个字符串"相加":
var longString="One piece"+"plus one more piece.";
要将多个字符串累积为一个字符串,还可以使用"+="操作符:
var result="";
result+="My name is Anders"
result+=" and my age is 25";
要在字符串中添加换行符,需要使用转义字符"/n":
var confirmString="You did not enter a response to the last"+
"question./n/nSubmit form anyway?";
var confirmValue= confirm(confirmString);
但这种方法只能用在像警告、确认对话框之类的情况下,如果将这段文本作为HTML内容呈现,就无效了,此时用"<br>"代替它:
var htmlString="First line of string.<br>Second line of string.";
document.write(htmlString);
String对象还提供了方法concat(),它完成与"+"相同的功能:
string.concat(value1, value2,...)
不过concat()方法显然不如"+"来得直观简洁。
3、访问字符串的子串
使用substring()或slice()方法(NN4+, IE4+),下面说明它们的具体用法。
substring()的原型为: string.substring(from, to)
第一个参数from指定了子字符串在原字符串中的起始位置(基于0的索引);第二个参数to是可选的,它指定了子字符串在原字符串的结束位置(基于0的索引),一般情况下,它应比from大,如果它被省略,那么子字符串将一直到原字符串的结尾处。
如果参数from不小心比参数to大了会怎样?JavaScript会自动调解子字符串的起止位置,也就是说,substring()总是从两个参数中较小的那个开始,到较大的那个结束。不过要注意,它包含起始位置的那个字符,但不包含结束位置的那个字符。
var fullString="Every dog has his day.";
var section= fullString.substring(0, 4);// section is"Ever".
slice()的原型为: string.slice(start, end)
参数start表示子串的起始位置,如果为负数,那么可以理解为倒数第几个开始,例如-3表示从倒数第三个开始;参数end表示结束位置,与start一样,它也可以为负数,其含义也表示到倒数第几个结束。slice()的参数可以为负数,所以要比substring()更加灵活,但没那么宽容了,如果start比end要大,它将返回一个空字符串(示例略)。
还有一个方法是substr(),其原型为: string.substr(start, length)
从原型可以看出它的参数的含义,start表示起始位置,length则表示子字符串的长度。JavaScript标准不提倡使用该方法。
4、字符串的大小写转换
使用toLowerCase()和toUpperCase()方法:
var city="ShanGHai";
city= city.toLowerCase();// city is"shanghai" now.
5、判断两个字符串是否相等
先将用户的输入值全部转换为大写(或小写),然后再行比较:
var name= document.form1.txtUserName.value.toLowerCase();
if(name=="urname")
{
// statements go here.
}
JavaScript有两种相等运算符。一种是完全向后兼容的,标准的"==",如果两个操作数类型不一致,它会在某些时候自动对操作数进行类型转换,考虑下面的赋值语句:
var strA="i love you!";
var strB= new String("i love you!");
这两个变量含有相同的字符序列,但数据类型却不同,前者为string,后者为object,在使用"=="操作符时,JavaScript会尝试各种求值,以检测两者是否会在某种情况下相等。所以下面的表达式结果为true: strA== strB。
第二种操作符是"严格"的"===",它在求值时不会这么宽容,不会进行类型转换。所以表达式strA=== strB的值为false,虽然两个变量持有的值相同。
有时代码的逻辑要求你判断两个值是否不相等,这里也有两个选择:"!="和严格的"!==",它们的关系就类似于"=="和"==="。
讨论:
"=="和"!="在求值时会尽可能地寻找值的匹配性,但你可能还是想在比较前进行显式的类型转换,以"帮助"它们完成工作。比如,如果想判断一个用户的输入值(字符串)是否等于一个数字,你可以让"=="帮你完成类型转换:
if(document.form1.txtAge.value== someNumericVar){...}
也可以提前转换:
if(parseInt(document.form1.txtAge.value)== someNumericVar){...}
如果你比较习惯于强类型的编程语言(比如C#,Java等),那么这里你可以延续你的习惯(类型转换),这样也会增强程序的可读性。
有一种情况需要注意,就是计算机的区域设置。如果用"<"和">"来比较字符串,那么JavaScript把它们作为Unicode来比较,但显然,人们在浏览网页时不会把文本当作Unicode来阅读:)比如在西班牙语中,按照传统的排序,"ch"将作为一个字符排在"c"和"d"之间。localeCompare()提供了一种方式,可以帮助你使用默认区域设置下的字符排序规则。
var strings;//要排序的字符串数组,假设已经得到初始化
strings.sort(function(a,b){ return a.localeCompare(b)});//调用sort()方法进行排序
6、字符串的查找
使用string的indexOf()方法:
strObj.indexOf(subString[, startIndex])
strObj为要进行判断的字符串,subString为要在strObj查找的子字符串,startIndex是可选的,表示查找的开始位置(基于0的索引),如果startIndex省略,则从strObj开始处查找,如果startIndex小于0,则从0开始,如果startIndex大于最大索引,则从最大索引处开始。
indexOf()返回strObj中subString的开始位置,如果没有找到,则返回-1。在脚本中,可以这么使用:
if(largeString.indexOf(shortString)!=-1)
{
//如果包含,进行相应处理;
}
也许一个字符串会包含另一字符串不止一次,这时第二个参数startIndex也许会派上用场,下面这个函数演示如何求得一个字符串包含另外一个字符串的次数:
function countInstances(mainStr, subStr)
{
var count= 0;
var offset= 0;
do
{
offset= mainStr.indexOf(subStr, offset);
if(offset!=-1)
{
count++;
offset+= subStr.length;
}
}while(offset!=-1)
return count;
}
String对象有一个与indexOf()对应的方法,lastIndexOf():
strObj.lastIndexOf(substring[, startindex])
strObj为要进行判断的字符串,subString为要在strObj查找的子字符串,startIndex是可选的,表示查找的开始位置(基于0的索引),如果startIndex省略,则从strObj末尾处查找,如果startIndex小于0,则从0开始,如果startIndex大于最大索引,则从最大索引处开始。该方法自右向左查找,返回subString在strObj中最后出现的位置,如果没有找到,返回-1。
sublime怎么自动生成代码
1、首先要熟悉sublime api,插件可以用python开发,这个很好,写好代码,保存到默认的目录应该是\SublimeText2\Data\Packages\User下面,
可以按下快捷键Ctrl+‘打开SublimeText的控制台,执行如下命令就可以运行刚刚写的小插件,测试效果:
Java代码
view.run_command('insert_signature')
2、为了方便使用需要绑定快捷键,在同目录下\SublimeText2\Data\Packages\User有快捷键文件 Default(操作系统类型).sublime-keymap 3个类似的文件,修改绑定快捷键即可,如下:
自动生成代码头代码如下:
Java代码
#coding=gbk
'''
Created on--::
@author: songpo
'''
#view.run_command('insert_codeheader')
import sublime, sublime_plugin, datetime
class insertSignatureCommand(sublime_plugin.TextCommand):
def run(self, edit):
date= datetime.datetime.now()
dateStr= date.strftime("%Y-%m-%d%X")
text_encode="""#-*- encoding: utf--*-\n'''\n"""
text_author="""\n\n@author: songpo\n'''\n"""
text= text_encode+'Created on'+ dateStr+ text_author
#for region in the selection
#一个region是一个选择块,一次可以选择多个块
for r in self.view.sel():
str_r= self.view.substr(r)#str_r是所选择块的文本内容
if'Created on' in str_r:
if'Updated on' in str_r:
text= str_r[:str_r.find('Updated on')]+'Updated on'+ dateStr+ text_author
else:
text= str_r.replace(text_author,'\nUpdated on'+ dateStr+ text_author)
self.view.erase(edit, r)
self.view.insert(edit, r.begin(), text)
参考博客:
1、自定义快捷键:
sublime的操作体验完全基于配置,如有你愿意多调整,完全可以按照自己的意愿重新定义一个操作体验,有2个快捷键配置文件系统和用户,应该是用户的
可以覆盖系统的,在preferences-按键绑定-系统/用户
即可打开配置。小试一下增加一个eclipse的功能,就是上下调整选中行,添加如下代码:
Java代码
{"keys": ["alt+up"],"command":"swap_line_up"},
{"keys": ["alt+down"],"command":"swap_line_down"},
2、Sublime Text 2的快捷键还支持双重组合,譬如默认情况下,将选中的文字改成大写的热键是“Ctrl+K,
Ctrl+U”,意思是当你先按下 Ctrl+K之后迅速再按 Ctrl+U
进行触发(只按下Ctrl+K是没有作用的),这样可以避免很多热键冲突,也可以更灵活更多选择地进行热键自定义
3、常用快捷键:
Shift+鼠标右键(Win)或 Option+鼠标左键(Mac)或使用鼠标中键可以用鼠标进行竖向多行选择
ctrl+p:雷电般快速的文件切换:
Ctrl+P(Win),这次试试先输入一个@号:随心所欲的跳转:快速罗列与定位函数/HTML的元素、跳转到指定行
更牛x的了来了,这些切换定位方法你还可以配合在一起使用!譬如我有一个名为”hello-iplaysoft.js”的文件,里面其中有一个
function叫做”visit_iplaysoft_com”,我现在想要编辑这个函数,那么我只需按下
Ctrl+P,然后输入“heip@vi”回车(模糊匹配,注意前面有颜色的字符),ST2
马上就给我到打开这个文件并定位进去了!够方便了吧?!熟记这几个快捷键,你可以很一气呵成地进行文件切换和编辑
------------------------------------
------------一下是mac版本配置--------------
------------------------------------
看考地址:
1、Sublime Text常用插件和设置
打开 Sublime Text 2后,可以在菜单中找到 Preferences-> Settings- User点击后,会打开一个编辑器窗口.在该编辑器窗口下,就可以输入当前用户的关配置了.我一般配置如下:
Java代码
{
"color_scheme":"Packages/Color Scheme- Default/Monokai.tmTheme",
"dictionary":"Packages/Language- English/en_GB.dic",
"font_size": 11.0,
"draw_white_space":"all",//显示空白字符,比如空格 tab
"font_size": 13.0,
"scroll_past_end": true,//当文件到末尾时还能继续滚动
"trim_automatic_white_space": false,//关闭自动删除每行前后空格
"ignored_packages":
[
"Vintage"
]
}
2、Package Control下载插件(格式化xml)
Package Control是用来管理 Sublime Text 2的插件的插件.也是装完后第一个要安装的插件.
首先打开 ctrl+`,并在打开的 st2 console中输入:
Java代码
import urllib2,os; pf='Package Control.sublime-package'; ipp=sublime.installed_packages_path(); os.makedirs(ipp) if not os.path.exists(ipp) else None; urllib2.install_opener(urllib2.build_opener(urllib2.ProxyHandler())); open(os.path.join(ipp,pf),'wb').write(urllib2.urlopen('('','%20')).read()); print'Please restart Sublime Text to finish installation'
安装完成后,应该就可以看到菜单下有 Preferences-> Package Settings选项了.
常用插件
上面的 Package Control安装完以后,就可以通过快捷键 command+ shift+ p并输入 install package,来选择需要安装的插件.
Alignment
这插件用于对齐代码赋值语句,例如:
var name="sublimt"
var version="2.0.1"
var title="sublime text"
按下快捷键后,会变成:
var name="sublimt"
var version="2.0.1"
var title="sublime text"
不过这插件默认使用的是 ctrl+ cmd+ a和那个抢了 5个全局个快捷键的QQ冲突,所以需要修改插件的快捷键.点击菜单 Preferences-> KeyBindings- User,加入如下内容
{"keys": ["super+ctrl+alt+]"],"command":"alignment"}
将快捷键修改成 ctrl+ opt+ cmd+ ],要改成什么其他的也请自行修改.
Vim模式
是的,Sublime Text 2 dev版已经支持 Vim的编辑模式了,如果更喜欢 Vim的编辑模式,可以通过以下方法来激活 Vintage mode:
按下 Shift+ Command+ P调出命令面板。
输入 settings user调出 Preferences:Settings- User,并按下回车。
以上两步也可以直接用cmd+,完成。
这时会打开一个 Preferences.sublime-settings的文件,如果是第一次修改,它应该是个空文件,把以下文本粘贴进去:
Java代码
{
"ignored_packages": []
}
保存这个文件,这时按下 ESC键,再按下一些你熟悉的 Vim命令,是不是很有亲切感
关于js中substr函数,js 数组方法的介绍到此结束,希望对大家有所帮助。