Estou experimentando formulários JavaScript e Drupal. Atualmente, estou tentando criar um botão no formulário de administração de um módulo que usará o JavaScript para anexar opções a uma lista de seleção. O problema que encontro é que, quando clico no botão, meu JavaScript é chamado, mas todo o formulário é atualizado. Eu olhei para a referência da API de formulários pensando que havia algum tipo de atributo que posso definir no botão para impedi-lo, mas não encontrei nada. Existe alguma maneira de impedir que o botão atualize a página ou isso é um beco sem saída?
$form['#attached']['js'] = array(
drupal_get_path('module', 'test').'/js/test.js',
);
$form['list'] = array(
'#type' => 'select',
'#options' => array(),
'#attributes' => array(
'name' => 'sellist',
),
'#size' => 4,
);
$form['add_button'] = array(
'#type' => 'button',
'#value' => 'Add',
'#attributes' => array(
'onclick' => "add_to_list(this.form.sellist, 'Append' + this.form.sellist.length);",
),
);
//JavaScript
function add_to_list(list, text) {
try {
list.add(new Option(text, list.length), null) //add new option to end of "sample"
}
catch(e) {
list.add(new Option(text, list.length));
}
}
Meu código final:
<?php
function jstest_menu() {
$items['admin/config/content/jstest'] = array(
'title' => 'JavaScript Test',
'description' => 'Configuration for Administration Test',
'page callback' => 'drupal_get_form',
'page arguments' => array('_jstest_form'),
'access arguments' => array('access administration pages'),
'type' => MENU_NORMAL_ITEM,
);
return $items;
}
function _jstest_form($form, &$form_state) {
$form['list'] = array(
'#type' => 'select',
'#options' => array(),
'#size' => 4,
);
$form['text'] = array(
'#type' => 'textfield',
);
$form['add_button'] = array (
'#type' => 'button',
'#value' => t("Add"),
'#after_build' => array('_jstest_after_build'),
);
return $form;
}
function _jstest_after_build($form, &$form_state) {
drupal_add_js(drupal_get_path('module', 'jstest').'/js/jstest.js');
return $form;
}
JavaScript
(function ($) {
Drupal.behaviors.snmpModule = {
attach: function (context, settings) {
$('#edit-add-button', context).click(function () {
var list = document.getElementById('edit-list');
var text = document.getElementById('edit-text');
if (text.value != '')
{
try {
list.add(new Option(text.value, list.length), null);
}
catch(e) {
list.add(new Option(text.value, list.length));
}
text.value = '';
}
return false;
});
$('#edit-list', context).click(function () {
var list = document.getElementById('edit-list');
if (list.selectedIndex != -1)
list.remove(list.selectedIndex);
return false;
});
}
};
}(jQuery));
7
forms
javascript
Sathariel
fonte
fonte
a definição do botão de formulário abaixo funciona para mim, o #after_build é útil para carregar em javascript que pode anexar o manipulador de cliques.
Então meu javascript, carregado em um arquivo separado pela função after build, se parece com:
fonte
Você pode simplesmente adicionar a
return false
instrução após sua chamada de função, dentro da linha de atributo do elemento do formulário do botão:fonte
Idealmente, leia as habilidades de forma AJAX (ou AHAH) do Drupal. Introdução realmente básica aqui http://drupal.org/node/752056
Caso contrário, estou surpreso ao atualizar a página, pois é apenas um 'botão', não um envio ou algo assim.
Ele precisa que o javascript retorne false, como em um link para impedi-lo de voltar ao topo da página?
fonte