V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
islujw
V2EX  ›  JavaScript

JS 获取 body 内 class 的数字字符串

  •  
  •   islujw · 2017-08-12 13:20:11 +08:00 · 2901 次点击
    这是一个创建于 2660 天前的主题,其中的信息可能已经有所发展或是发生改变。

    body 内有许多个 class,如:

    <body class="default-template postid-123">
    

    需要定位到前面是 "postid-" 的,并获取 123 这个字符串(长度不一定是 3 位)。

    请问怎么做呢?将为第一个可用的答案发送感谢铜币。

    9 条回复    2017-08-28 11:49:55 +08:00
    soratadori
        1
    soratadori  
       2017-08-12 13:30:47 +08:00
    正则表达式

    另外,铜币有啥用?
    cojing
        2
    cojing  
       2017-08-12 13:31:50 +08:00
    \d+
    正则匹配数字就好
    ferrum
        3
    ferrum  
       2017-08-12 13:32:48 +08:00   ❤️ 1
    ```
    var classnames = 'default-template postid-123'
    var regId = /postid-([\d]+)/
    var result = classnames.match(regId)
    console.log(result[1])
    ```
    老老实实问问题就行,别铜币来铜币去的。
    geelaw
        4
    geelaw  
       2017-08-12 13:39:21 +08:00   ❤️ 1
    var result = / postid-([-_0-9a-zA-Z]+) /.exec(' ' + document.body.className + ' ');
    result = result && result[1];

    // 以上代码可以覆盖绝大多数情况了
    islujw
        5
    islujw  
    OP
       2017-08-12 14:22:30 +08:00
    @ferrum 谢谢,两者并不矛盾。铜币表示对帮助的尊重,虽然这个问题自己也试了一下,但我不希望被当作伸手党。
    oott123
        6
    oott123  
       2017-08-12 17:51:58 +08:00 via Android
    @geelaw 为啥前后都要拼空字符串呢?如果只是为了保证 string 类型,那么前面拼就可以了。
    geelaw
        7
    geelaw  
       2017-08-12 18:26:10 +08:00 via iPhone
    @oott123 习惯,懒得思考
    islujw
        8
    islujw  
    OP
       2017-08-12 19:19:02 +08:00
    @ferrum class 名称不是固定的,有不定数量的 class,且一定包括 postid- 开头的。需要配合使用 document.body.className
    flowfire
        9
    flowfire  
       2017-08-28 11:49:55 +08:00
    /(?: |^)postid-(\d+)(?: |$)/
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1826 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 16:32 · PVG 00:32 · LAX 08:32 · JFK 11:32
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.