繁体   English   中英

从内容页面中的视图访问控件

[英]Access controls from view in content page

参考我之前的问题 ,我有3个观点 图片 我这里有一个输入字段说名称,我有一个保存工具栏按钮。 保存图标放在我的内容页面上,而输入字段在我的视图中。 点击保存后,我想将文本框中的数据保存到XML文件中。 由于我的保存点击事件位于我的内容页面中,因此无法从我的视图中输入文本。

这是代码片段:

查看页面:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection.Emit;
using System.Text;

using Xamarin.Forms;

namespace ____
{
    public class View1 : ContentView
    {
        public static Entry txtName;

        public View1()
        {

            //Name
            Label lblName = new Label { Text = "Name", FontAttributes = FontAttributes.Bold, Style = (Style)Application.Current.Resources["LabelStyle"] };

            txtName = new Entry { Style = (Style)Application.Current.Resources["entryStyle"] };


            StackLayout stName = new StackLayout
            {
                Padding = new Thickness(10, 0, 10, 0),
                Children ={ 
                    lblName,
                    txtName
                }
            };

            var scrollview = new ScrollView
            {
                Content = new StackLayout
                {
                    Padding = new Thickness(0, 20, 0, 20),
                    //VerticalOptions = LayoutOptions.StartAndExpand,
                    Children = {stName
                }
                }
            };
            Content = new StackLayout
            {
                Padding = new Thickness(0, 20, 0, 20),
                VerticalOptions = LayoutOptions.StartAndExpand,
                Children =
                {

                    scrollview

                }
            };


        }
    }
}

内容页:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection.Emit;
using System.Text;

using Xamarin.Forms;

namespace ___
{
    public class Page1 : ContentPage
    {
         Button btnDetails, btnN, btnT;
        View1 myview1, myview2, myview3;
        public Page1()
        {
            //Primary Items
            ToolbarItem Save = new ToolbarItem();
            Save.Text = "Save";
            Save.Clicked += OnClick_Save;
            Save.Order = ToolbarItemOrder.Primary;
            Save.Icon = Device.OnPlatform("Icons/save.png", "save.png", "Toolkit.Content/save.png");

            ToolbarItem Cancel = new ToolbarItem();
            Cancel.Text = "Cancel";
            //Cancel.Clicked += OnClick_Cancel;
            Cancel.Order = ToolbarItemOrder.Primary;
            Cancel.Icon = Device.OnPlatform("Icons/cancel.png", "cancel.png", "Images/cancel.png");


            ToolbarItems.Add(Cancel);
            ToolbarItems.Add(Save);


            StackLayout stHeader = new StackLayout
            {
                Children = { 
                                new Label {
                                    Text= "--------", FontAttributes=FontAttributes.Bold, FontSize=25, TextColor=Color.FromHex("#2C3E50")
                                }
                            },
                HorizontalOptions = LayoutOptions.FillAndExpand,
                Padding = new Thickness(10, 0, 0, 10)
            };

            btnDetails = new Button { Text = "Details", HorizontalOptions = LayoutOptions.FillAndExpand };
            btnN = new Button { Text = "---", HorizontalOptions = LayoutOptions.FillAndExpand };

            btnT = new Button { Text = "---", HorizontalOptions = LayoutOptions.FillAndExpand };

            Grid objGrid = new Grid();
            objGrid.RowDefinitions.Add(new RowDefinition { Height = GridLength.Auto });

            objGrid.RowDefinitions.Add(new RowDefinition { Height = GridLength.Auto });
            objGrid.RowDefinitions.Add(new RowDefinition { Height = new GridLength(1, GridUnitType.Star) });

            //objGrid.RowDefinitions.Add( new RowDefinition { Height = GridLength.Auto });
            //
            objGrid.ColumnDefinitions.Add(new ColumnDefinition
            {
                Width = new GridLength(1, GridUnitType.Star)
            });
            objGrid.ColumnDefinitions.Add(new ColumnDefinition
            {
                Width = new GridLength(1, GridUnitType.Star)
            });
            objGrid.ColumnDefinitions.Add(new ColumnDefinition
            {
                Width = new GridLength(1, GridUnitType.Star)
            });

            objGrid.Children.Add(stHeader, 0, 0);
            Grid.SetColumnSpan(stHeader, 3);

            btnDetails.Clicked += ButtonClicked;
            objGrid.Children.Add(btnDetails, 0, 1);//col, row

             btnN.Clicked += ButtonClicked;
             objGrid.Children.Add(btnN, 1, 1);

             //btn3 = new Button { Text = "3" };
             btnT.Clicked += ButtonClicked;
             objGrid.Children.Add(btnT, 2, 1);

            myview1 = new View1();
            myview2 = new View1();
            myview3 = new View1();

            objGrid.Children.Add(myview1, 0, 2);
            objGrid.Children.Add(myview2, 0, 2);
            objGrid.Children.Add(myview3, 0, 2);

            Grid.SetColumnSpan(myview1, 3);
            Grid.SetColumnSpan(myview2, 3);
            Grid.SetColumnSpan(myview3, 3);

            Content = objGrid;
            SelectButton(btnDetails);
        }

        private void OnClick_Save(object sender, EventArgs e)
        {
            var s = View1.txtName.Text;

        }

        void SelectButton(Button button)
        {
            View1 view = null;
            if (button == btnDetails)
                view = myview1;
            if (button == btnN)
                view = myview2;
            if (button == btnT)
                view = myview3;
            myview1.IsVisible = myview1 == view;
            myview2.IsVisible = myview2 == view;
            myview3.IsVisible = myview3 == view;
            btnDetails.TextColor = (btnDetails == button) ? Color.Accent.AddLuminosity(0.18) : (Color)Button.TextColorProperty.DefaultValue;
            btnN.TextColor = (btnN == button) ? Color.Accent.AddLuminosity(0.18) : (Color)Button.TextColorProperty.DefaultValue;
            btnT.TextColor = (btnT == button) ? Color.Accent.AddLuminosity(0.18) : (Color)Button.TextColorProperty.DefaultValue;
            btnDetails.BackgroundColor = (btnDetails == button) ? Color.Silver.AddLuminosity(0.18) : Color.Silver.AddLuminosity(0.1);
            btnN.BackgroundColor = (btnN == button) ? Color.Silver.AddLuminosity(0.18) : Color.Silver.AddLuminosity(0.1);
            btnT.BackgroundColor = (btnT == button) ? Color.Silver.AddLuminosity(0.18) : Color.Silver.AddLuminosity(0.1);
        }

        void ButtonClicked(object sender, EventArgs e)
        {
            SelectButton((Button)sender);
        }
    }
}

如何在我的内容页面保存按钮单击中输入文本框值?

您可以尝试将Entry控件公开为View1示例的属性:public Entry TextName {get {return txtName; }}

您的页面可能会访问此页:

string value = myView1.TextName.Text

使用实例成员引用而不是静态引用:

  1. View1类中,更改public static Entry txtName; to public Entry txtName;
  2. 添加一个新字段View1 _currentView; Page1类。
  3. SelectButton()方法的最后,添加_currentView = view;
  4. 最后,在OnClick_Save() ,更改var s = View1.txtName.Text; to var s = _currentView.txtName.Text;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM