感到 Markdown 不是技术社区合适的标记语言 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
jiyinyiyong
V2EX    分享发现

感到 Markdown 不是技术社区合适的标记语言

  •  
  •   jiyinyiyong 2013-06-10 17:09:17 +08:00 4924 次点击
    这是一个创建于 4535 天前的主题,其中的信息可能已经有所发展或是发生改变。
    从我在知乎被教育说 Markdown 是对技术社区很从的标记语言
    到自己在 Github 和 CNode 长期使用 Markdown 发帖回帖到现在对 Markdown 产生反感,,
    我并不是用 Markdown 太少, 也不是说 Markdown 在任意场景都不合适
    我是说, 对于参数人数多的技术社区, Markdown 存在若干问题:



    * 有人不用 Markdown 标记代码

    没有高亮的代码是难读的, 用非等宽字体简直就有些可恨了
    但国内技术社区, 特别新人增多之后, 不用 Markdown 的例子很多
    我在 CNode 水贴, 隔几天就会遇到提问不加语法标记的
    有时候行内代码, 图个方便, 也不想加代码标记了
    结果就是没有标记的 log 或者代码, 各种损害网站的界面

    对此我尝试了 `white-space: pre-wrap`, 以及强制等宽字体的方案
    结果是空行包裹加四空格缩进的内容被标记为代码块, 代码依旧出现问题
    而去掉代码区域标记使之融入背景的做法又导致大量反感
    剩下只有让 Markdown 不标记缩进代码, 改动编译器, 同样不成



    * 控制复杂的空行

    ```
    * item
    * item
    ```



    ```
    * item

    * item
    ```

    因为中间空格的关系, 可能会被加上一层 `<p>` 标签来标记为段落
    Markdown 对换行的处理纠缠已久, 很可能就会在书写时多个少个空行
    同个人写还是能统一间距, 但论坛上喜欢未必统一, 于是 CSS 设置的间距就不定了

    同样创建更多的空白在 Markdown 里并不是那么自由, `\n\n` 会被压缩



    * 不是所见所得

    个人博客上的 Markdown 由自己控制, 虽然坑人, 但遵守规范时视觉效果稳定的
    但论坛上的, 一般是修改了手动点击按钮切换预览, 写长文就很蛋疼了
    在处理 CNode 问题的时候, pre-wrap 带来更多的影响, 问题特别明显
    因为不是所见所得, 排版成了不小的问题.. 但同时也被其他影响放大



    * 缩进的编辑器支持

    既然 Markdown 支持编辑代码, 就很自然有想在输入框编辑代码的需求
    但 Web 上的 `<textarea>` 默认就没有自动管理缩进的功能
    引入第三方的编辑器反而页面和编辑工作显得臃肿, 不如文本框那么轻便和熟悉



    ------



    个人博客, 高素质的社区, 我不感到 Markdown 有不适
    但通常技术社区都是有大量新人涌入, Markdown 本身对新人是门槛
    而新人使用不恰当对社区整个排版也造成各种影响..
    因此我认为 Markdown 不合适
    6 条回复    1970-01-01 08:00:00 +08:00
    Perry
        1
    Perry  
       2013-06-10 17:18:52 +08:00
    这些都不是Markdown本身存在的错误吧
    既然一个社区要用到Markdown,那么必要的tutorials还是有的。
    jiyinyiyong
        2
    jiyinyiyong  
    OP
       2013-06-10 17:34:33 +08:00
    @Perry 对, 没说是 Markdown 错误, 主要是不通用, 不合适

    基本的教程在 CNode, Ruby China, Github 都是发帖时很容易看到的
    但对于新手来说, 只有主动和他们直接说两边遍才是充分的
    davepkxxx
        3
    davepkxxx  
       2013-06-10 17:37:57 +08:00
    等宽字体不是 CSS 的事情吗?和 Markdown 有什么关系?
    jiyinyiyong
        4
    jiyinyiyong  
    OP
       2013-06-10 18:35:38 +08:00
    没有用 Markdown 标记的代码, 只能用两条 CSS 来减缓
    当然这已经超出 Markdown 的考虑范围了
    otakustay
        5
    otakustay  
       2013-06-10 21:07:20 +08:00
    我认为的markdown的主要问题:

    1. code块不能指定是什么语言(于是有了gfm)
    2. 没有table、dl的支持(于是有了markdown extra)
    3. 没有abbr、mark的支持,这个暂时无解,而abbr在技术社区很有用
    4. 没有ins和del的支持,这个是非常严重的问题
    4. *错误*地将em和strong用同一个符号以不同数量为区分进行标记,这个我认为是硬伤,em和strong很常用,因此更应该用不同的符号,如*标记em,而_标记strong,而不是以*和**来区分
    jiyinyiyong
        6
    jiyinyiyong  
    OP
       2013-06-10 21:22:50 +08:00
    @otakustay 基本同意, 但我觉得我对 Markdown 的期望其实也不在乎它其实很多毛病了
    如果有更完善的所见所得的编辑器方案, 相信 Markdown 依旧是问题重重
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     856 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 22:13 PVG 06:13 LAX 14:13 JFK 17:13
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86