Partilhar via


L2DBForm.xaml.cs código-fonte

Esta página contém o conteúdo e a descrição do código-fonte C# no arquivo L2DBForm.xaml.cs. A classe parcial L2XDBForm contida neste arquivo pode ser dividida em três seções lógicas: membros de dados e os manipuladores de eventos de clique de botão OnRemove e OnAddBook.

Membros de dados

Dois membros de dados privados são usados para associar essa classe aos recursos de janela usados em L2DBForm.xaml.

  • A variável de namespace myBooks é inicializada para "http://www.mybooks.com".

  • O membro bookList é inicializado no construtor com a cadeia de caracteres CDATA em L2DBForm.xaml utilizando a seguinte linha:

    bookList = (XElement)((ObjectDataProvider)Resources["LoadedBooks"]).Data;
    

Manipulador de eventos OnAddBook

Este método contém as seguintes três instruções:

  • A primeira instrução condicional é usada para validação de entrada.

  • A segunda instrução cria um novo XElement a partir dos valores em formato de texto que o utilizador inseriu na seção Adicionar Novo Livro interface de utilizador (UI).

  • A última instrução adiciona esse novo elemento book ao provedor de dados em L2DBForm.xaml. Consequentemente, a vinculação dinâmica de dados atualizará automaticamente a interface do usuário com esse novo item; nenhum código extra fornecido pelo usuário é necessário.

Manipulador de eventos OnRemove

O manipulador de OnRemove é mais complicado do que o manipulador de OnAddBook por dois motivos. Primeiro, como o XML bruto contém espaços em branco preservados, as novas linhas correspondentes devem também ser removidas juntamente com a entrada do livro. Em segundo lugar, como uma comodidade, a seleção, que estava no item apagado, é redefinida para o anterior da lista.

No entanto, o trabalho principal de remover o item de livro selecionado é realizado por apenas duas instruções:

  • Primeiro, o elemento livro associado ao item atualmente selecionado na caixa de seleção é recuperado.

    XElement selBook = (XElement)lbBooks.SelectedItem;
    
  • Em seguida, esse elemento é excluído do provedor de dados:

    selBook.Remove();
    

Novamente, a associação dinâmica de dados garante que a interface do usuário do programa seja atualizada automaticamente.

Exemplo

Código

using System;
using System.Linq;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Input;
using System.Xml;
using System.Xml.Linq;

namespace LinqToXmlDataBinding {
    /// <summary>
    /// Interaction logic for L2XDBForm.xaml
    /// </summary>

    public partial class L2XDBForm : System.Windows.Window
    {
        XNamespace mybooks = "http://www.mybooks.com";
        XElement bookList;

        public L2XDBForm()
        {
            InitializeComponent();
            bookList = (XElement)((ObjectDataProvider)Resources["LoadedBooks"]).Data;
        }

        void OnRemoveBook(object sender, EventArgs e)
        {
            int index = lbBooks.SelectedIndex;
            if (index < 0) return;

            XElement selBook = (XElement)lbBooks.SelectedItem;
            //Get next node before removing element.
            XNode nextNode = selBook.NextNode;
            selBook.Remove();

            //Remove any matching newline node.
            if (nextNode != null && nextNode.ToString().Trim().Equals(""))
            { nextNode.Remove(); }

            //Set selected item.
            if (lbBooks.Items.Count > 0)
            {  lbBooks.SelectedItem = lbBooks.Items[index > 0 ? index - 1 : 0]; }
        }

        void OnAddBook(object sender, EventArgs e)
        {
            if (String.IsNullOrEmpty(tbAddID.Text) ||
                String.IsNullOrEmpty(tbAddValue.Text))
            {
                MessageBox.Show("Please supply both a Book ID and a Value!", "Entry Error!");
                return;
            }
            XElement newBook = new XElement(
                                mybooks + "book",
                                new XAttribute("id", tbAddID.Text),
                                tbAddValue.Text);
            bookList.Add("  ", newBook, "\r\n");
        }
    }
}

Observações

Para ver o código fonte XAML associado a esses manipuladores, consulte L2DBForm.xaml.

Ver também