我正在尝试创建一个MediaWiki解析器扩展,它将创建一个表,解析后的参数将用于dataTables脚本的ajax URL。
$wgHooks['ParserFirstCallInit'][] = 'AllQuesttableFunction';
$wgExtensionMessagesFiles['AllQuestTable'] = __DIR__ . '/_questtable.i18n.php';
function AllQuesttableFunction( &$parser ) {
$parser->setFunctionHook( 'questtable', 'AllQuestTableParserFunction' );
return true;
}
function AllQuestTableParserFunction( &$parser, $arg1='', $arg2='', $arg3='' ) {
$tableend = '<br><div class="hbody"><table class="lists list_basicitem width_100p" id="serverTable"><thead><tr><th>Area</th><th>Quest Name</th><th>Min<br>Level</th><th style="width:200px !important">Rewards</th></tr></thead></table><div class="cl"></div></div>';
return array( $tableend, 'noparse' => true, 'isHTML' => true );
}
$wgHooks['ParserBeforeTidy'][] = 'wgAddJquery';
function wgAddJquery(&$parser, &$text) {
global $addJqueryScripts, $wgLang;
$code = $wgLang->getCode();
if ($addJqueryScripts === true) return true;
$parser->mOutput->addHeadItem(
' <script type="text/javascript" language="javascript" src="http://mywiki.com/wiki/extensions/DataTables/DataTables-1.10.0/media/js/jquery.js"></script>
<script type="text/javascript" language="javascript" src="http://mywiki.com/wiki/extensions/DataTables/DataTables-1.10.0/media/js/jquery.dataTables.js"></script>
<script type="text/javascript" language="javascript" >
$(document).ready(function() {
var dataTable = $("#serverTable").DataTable( {
"columnDefs": [
{
targets: 0,
className: \'al\'
},
{
targets: 1,
className: \'al\',
type: "num-html"
},
{
targets: 2,
className: \'ar\'
},
{
targets: 3,
className: \'al\'
},
{ targets: \'no-sorting\', orderable: false }
],
"processing": true,
"language": {
"processing": "<img src=\'2.gif\'>"
},
"serverSide": true,
"order": [[ 2, "desc" ]],
"ajax":{
url :"http://mywiki.com/wiki/extensions/quest_tables/_questtables_ajax.php?lowerlevel=' . $arg1 . '&higherlevel=' . $arg2 . '&race=' . $arg3 . '&lang=en",
type: "post",
}
} );
} );
</script>'
);
$addJqueryScripts = true;
return true;
}
我使用了此处提供的代码 Mediawiki Extension add Javascript in Header
用于向标题添加脚本但是 首先,它将它添加到每个页面,我只想在具有魔术字的页面上。 第二,它似乎是在AllQuestTableParserFunction之前推动wgAddJquery方式,这意味着我不能在dataTables脚本中使用解析的参数。
TL;博士 有一个页面{{#magicword:arg1 | arg2 | arg3}}。所有3个参数都被解析为一个扩展,其中一个函数创建一个表,第二个将一个脚本添加到标题中,这三个参数作为ajax的url的一部分,并且仅在该页面上。我不需要其他任何地方的脚本。
有任何建议或甚至不可能吗?
答案 0 :(得分:0)
您应该使用$parser->getOutput()->addModules(...)
,但这不是重点?
为什么需要ParserBeforeTidy钩子?如果您只想在遇到解析器函数时添加脚本,为什么不从解析器函数处理程序方法中执行此操作?