MediaWiki:Common.js:修订间差异
外观
| 第38行: | 第38行: | ||
var $avatarWrapper = $( '<span class="sp-avatar-wrapper" style="vertical-align: middle; margin-right: 4px; display: inline-block;"></span>' ).html( avatarHtml ); | var $avatarWrapper = $( '<span class="sp-avatar-wrapper" style="vertical-align: middle; margin-right: 4px; display: inline-block;"></span>' ).html( avatarHtml ); | ||
$avatarWrapper.find( 'img' ).css( { | $avatarWrapper.find( 'img' ).css( { | ||
width: '2em', | |||
height: '2em', | |||
objectFit: 'cover', | |||
display: 'inline-block', | |||
verticalAlign: 'middle', | |||
border: 'var(--background-color-neutral, #eaecf0) 2px solid', | |||
boxSizing: 'border-box' | |||
} ); | |||
$link.before( $avatarWrapper ); | $link.before( $avatarWrapper ); | ||
} | } | ||
2026年2月26日 (四) 11:10的版本
//用户名前显示头像
mw.loader.using( 'mediawiki.util', function () {
$( document ).ready( function () {
function addAvatarsToElements( $elements ) {
$elements.each( function () {
var $link = $( this );
if ( $link.prev( '.sp-avatar-wrapper' ).length ) {
return;
}
if ( $link.closest( '#p-views' ).length || $link.closest( '#p-cactions' ).length || $link.closest( '#p-tb' ).length || $link.closest( '#right-navigation' ).length ) {
return;
}
var href = $link.attr( 'href' );
if ( !href ) return;
var userPart = decodeURIComponent( href.split( '/wiki/' )[1] );
if ( !userPart ) return;
if ( userPart.indexOf( '/' ) !== -1 ) {
return;
}
var userName = userPart.replace( /^User:|^用户:/, '' ).replace(/_/g, ' ');
var linkText = $link.text().trim().replace(/^User:|^用户:/, '');
if ( linkText !== userName ) {
var $target = $link.find( 'span, bdi' ).first();
var targetText = $target.length ? $target.text().trim().replace(/^User:|^用户:/, '') : '';
if ( !$target.length || targetText !== userName ) {
return;
}
}
new mw.Api().get( {
action: 'parse',
text: '{{#avatar:' + userName + '|l}}',
contentmodel: 'wikitext',
disablelimitreport: true,
disableeditsection: true
} ).done( function ( data ) {
if ( data.parse && data.parse.text ) {
var avatarHtml = data.parse.text[ '*' ];
var $avatarWrapper = $( '<span class="sp-avatar-wrapper" style="vertical-align: middle; margin-right: 4px; display: inline-block;"></span>' ).html( avatarHtml );
$avatarWrapper.find( 'img' ).css( {
width: '2em',
height: '2em',
objectFit: 'cover',
display: 'inline-block',
verticalAlign: 'middle',
border: 'var(--background-color-neutral, #eaecf0) 2px solid',
boxSizing: 'border-box'
} );
$link.before( $avatarWrapper );
}
} );
} );
}
addAvatarsToElements( $( 'a[href*="/wiki/User:"], a[href*="/wiki/%E7%94%A8%E6%88%B7:"], a[href*="/wiki/用户:"]' ) );
var observer = new MutationObserver( function ( mutations ) {
mutations.forEach( function ( mutation ) {
$( mutation.addedNodes ).find( 'a[href*="/wiki/User:"], a[href*="/wiki/%E7%94%A8%E6%88%B7:"], a[href*="/wiki/用户:"]' ).each( function() {
addAvatarsToElements( $( this ) );
} );
} );
} );
observer.observe( document.body, { childList: true, subtree: true } );
} );
} );