这次内容又是由携程负责seo的大拿安琦供稿,如果你也有如此之多的独到见解或干货,敬请联系我们。比如可以在微信公众号给我们留言,可以在站长社区发帖等等。我们期待找到你!5 X1 j& w2 }: C# Z- T6 Y+ q$ X
下面进入正文:8 U( P5 I0 M( {
开篇先摘一段新闻《中国智能手机市场6年首现负增长》。! @" b$ Q }8 q/ F4 ], A: c6 ~/ ^
文中指出:“IDC报告显示,2015年第一季度中国手机市场出货量为1.1亿部左右,同比下滑3.7%。其中智能手机市场出货量为1亿部左右,同比下降2.5%。这是过去6年以来,中国智能手机市场第一次出现季度同比下滑的情况。”2 w; m+ P2 |6 m! N) D8 p9 A! \; P
这意味这什么呢?# L- y1 w0 A0 I; L$ r6 z% Q
简单说,我国智能机不但普及,且已趋饱和,移动红利即将消耗贻尽。
8 t0 a8 }5 x/ X# A, M) z2 f那对于网站优化人员又意味着什么?0 t, r( k i' I$ d+ ^
结果上讲,重大网站没有完成移动化需亡羊补牢,南孚电影网 中小网站去完成移动化迫在眉睫。
4 n9 F. P) ?3 j2 k: Q2 g% ^3 _, l制作出用户体验良好的手机页面只是万事俱备,最为关键的临门一脚是获得搜索引擎的青睐,这样才能得到精准的用户,很多网站拥有PC和移动两套页面,从经验上看,精准、高效地被搜索引擎识别不但促进移动页面的排名和流量获取,对PC页面也有额外的效果加成。
2 I: q" A6 c, ]: g在经历了一轮轮移动H5项目,看过很多移动页面识别和优化的国外文章,更重要的是多次和百度相关人对话和解决问题后,我将一些常见的HTML识别细节总结了两部分,用于促进移动页面被搜索引擎识别、收录,让更多优质流量更早、更多地分发到自己页面。 j4 c; p& F ^% P
一、head标签中的部分4 }5 t; q& y& w# H9 m/ ^
1.URL设计
0 d5 i- ~& u/ _8 UURL尽量含有通用已成趋势的移动命名,例如“m./wap./3g./mobi./mobile./mob/wml/”,可以在子域名等方面体现. y" P9 M/ w" N4 p+ Y% H4 ?0 U* \
2.页面顶部的doctype标签
9 S/ a. ^0 d/ @5 c作为协议的重要部分,doctype中是否移动化也很重要,检查是否存在与移动相关的声明,如这些关键词,openmobilealliance, xhtml-mobile, xhtml-basic,wapforum,dtd compact html
2 @' }" q9 a1 a. {( K, l例:“<!DOCTYPE html PUBLIC “-//WAPFORUM//DTD XHTML Mobile 1.0//EN”””>”5 @' ?7 g2 p) R4 \! x# r. I# [- H
3.meta标签中的viewport属性和x-ua-compatible 属性 @; h( u- P2 T* x( s, u
viewport,移动前端开发中最重要的标签,响应式设计的根基,如果你的页面是遵守响应式设计的,那么说明这些页面对移动设备有友好的输出。0 w; r/ \7 H4 h4 U8 E
典型的的viewport代码是这样的,<meta name=“viewport” content=“width=device-width, initial-scale=1.0″>,判断移动与否的关键属性值为width,如果width=device-width这是典型的移动友好的设计,增加判定为移动页面的砝码,人人电影网 如果width有具体值,且值大于典型的移动屏幕(应该小于600),那么该页面被判定为PC页面的几率大大增加。
0 ^. r7 e* i6 D+ s但,META中还有一个很独特的属性作为SEO人员应该很少接触到,那就是x-ua-compatible 属性,该属性是PC意味非常强烈的功能性代码。示例代码如此,<meta http-equiv=”X-UA-Compatible” content=”IE=9; IE=8; IE=7; IE=EDGE” />,从百度工程师处得知,该代码会有较强暗示当前页面为PC页面的功能,需选择性使用。
2 T7 [$ m# ^' c i- g4.title中的移动暗示4 K; x* Q0 d; G% `8 {/ k4 B
制作移动页面时,在title标签中写明:“移动版”、“手机版”、“WAP版”、“触屏版”不仅是照顾用户体验的方案,也利于页面的移动识别,反之PC页面要谨慎使用这些文案。
) D: N4 Z; [: u5.链接link标签的media和href属性中需要注意的细节(多为样式文件)
1 u; n8 C" q( a7 g/ q) v1 {media属性值为screen时,表示屏幕中的显示样式,link的href所填写的URL(基本为样式文件的URL)就比较重要了,一定程度加大不同设备的偏重。此时URL中尽量出现/wap,/mobile/这样的命名,同URL设计一样,用于提高页面识别为移动的效率和概率。
% U: G" @- V; w! t! M如URL中含有pc字样则加大识别为PC页面的几率。
% }! n8 X& `5 f' | a6.一些通用的PC类识别HTML代码5 j6 z: c9 Q: p
embed:经常用于嵌入多媒体8 t0 b) H/ P) e: P' p5 r8 c
object:用于嵌入对象
% h) u2 }: a" O+ S/ ?! y6 x3 ^marquee:老旧的滚动特效实现代码5 T4 h2 d- w# V! F- P
iframe:想必网站优化人员很熟悉了,唯爱影视 典型的PC常用标签
0 E) ~" ~- S% O这些典型的用于PC或者老旧的、HTML5已经有更高效替代方案的旧标签,意味着使用它们将增加页面的PC属性,需要有目的地取舍。0 a. \) G0 R1 G$ N
7.一些javascript中典型的PC特征
- k0 C& P: W" t9 Z+ _& G加载swfobject、含有activexobject语句:移动页面根本不会使用如此重的多媒体引用方案(不信你问问你的前端工程师)
+ c! d1 |: }8 n. V1 _1 U/ G9 @含有netscape(网景)、msie(IE)、firefox(火狐)、browser.msie(IE)这些典型的非移动端浏览器兼容代码的
4 `! d9 C7 q$ z& D6 V# S设置了timer的 ,以及JS代码含有settimeout,的(此处不知道为什么设置timer还有识别的问题)
9 c0 x/ p W ?; d" k# ^均大幅增加识别为PC页面的可能性
, d! n# \7 o" R* D9 p& W. E以上这些<head></head>中出现的内容,
. A! ?0 _, l, ^, N+ }二、正文body中需要注意的部分
7 Z! v$ @/ `4 O( z8 I4 s9 |% ?链接和文本遵照的原则基本与head中一样——多出现移动相关的字眼;页面设置的宽度不要超过常规移动设备的大小;那些常识中(除非招错前端工程师)绝对只用于PC的一些兼容性代码。5 b4 T' T. g: k" n4 G* N
此外div块的个数也值得注意,没有哪家移动页面会过量使用div块;还有典型的只用于适配PC机器的HTML代码,例如:accesskey(如果移动页面用,要不前端招错人了,要不产品招错人了,应该引起警觉)head和正文两大部分,蓝花瓣电影网 基本涵盖了一张页面最主要的部分。: |- P7 w( Z+ _* s/ d) b8 [
网站优化人员一定要把握这些使用细节,协助前端工程师从正反方向将公司的PC和手机页面泾渭分明地呈现给搜索引擎。试想如果你每日被抓取页面达到90%的识别率,而一般水平是70%,这种优化增量是非常显著的。" S% {4 U! n9 O& h
最后,分享一个机器学习的思想给网站优化的新人,此文中心思想截取如下:. f1 C) @! ^* o! l; w0 A. i0 H
你从市场上的芒果里随机的抽取一定的样品(训练数据), 制作一张表格, 上面记着每个芒果的物理属性, 比如颜色, 大小, 形状, 产地, 卖家, 等等。(这些称之为特征)。
7 r+ h+ K3 n; c4 q! I1 X还记录下这个芒果甜不甜, 是否多汁,是否成熟(输出变量)。你将这些数据提供给一个机器学习算法(分类算法/回归算法),然后它就会学习出一个关于芒果的物理属性和它的质量之间关系的模型。
! p( M* |+ f9 \/ P* @9 ]/ s& ?下次你再去市集, 只要测测那些芒果的特性(测试数据),然后将它输入一个机器学习算法。算法将根据之前计算出的模型来预测芒果是甜的,熟的, 并且/还是多汁的。8 S2 [7 t% E2 K* ^. P
结合本文中的内容、再结合你已经烂熟于心的搜素引擎工作原理,设想一下,你的所有页面都是芒果,百度是带有识别模型(且该模型会自己训练、纠正自己)的芒果鉴别器,怎么让你的芒果持续性地、每次被拿起来都进入那个又大、贝窝热播网 又甜、又多汁的篮子?那些一眼就看出来的大甜芒果当然好判断,那些一眼看不出来的呢?我们能不能多生产些一眼就看出来好坏的芒果呢?这样整个果园是不是好收割一点?
0 N# |- B, Y2 V, B文章中的html细节就是模型的冰山一角。; c4 B8 F" X1 a4 F+ U1 A4 h7 v
: t! s$ e d4 f, |4 P9 x
|