javascript - termsAndCONditions 使用 WebView 和按钮滚动

标签 javascript webview xamarin.forms

我想实现一个 ContentPage,它有一个 WebView(html 文本)和“我同意”和“取消”按钮

问题:我想要一个 webView 插入到堆栈中,因此,我必须声明宽度和高度。 高度是我的主要问题,因为我想跨越或 FillAndExpend WebView。

所以我追求 webView.Eval("some js code") 函数,但我无法获得返回值(html的高度?) 另外,我以不同的方式进行处理,在 webView onBottom 时获取事件,然后获取一些 bool 值。

这是代码:

StackLayout mainStackLayout = new StackLayout { VerticalOptions = LayoutOptions.Center, HorizontalOptions = LayoutOptions.Center };

        Frame f = new Frame { BackgroundColor = Constants.iBackgroundWhite };
        StackLayout motherStack = new StackLayout { Margin = new Thickness(15, 30) };

        StackLayout buttonStack = new StackLayout
        {
            Orientation = StackOrientation.Horizontal,
            VerticalOptions = LayoutOptions.Center,
            HorizontalOptions = LayoutOptions.Center,
            Margin = new Thickness(0, 10)
        };
        Label captionLabel = new Label
        {
            Text = "Terms and Conditions",
            TextColor = Constants.iPink,
            FontAttributes = FontAttributes.Bold,
            FontSize = 25,
            Margin = new Thickness(10, 0, 0, 15)
        };


        var body = new HtmlWebViewSource();
        body.Html = @"<html><body>
 Lorem ipsum dolor sit amet, utinam tritani interpretaris mel ei, perfecto 
 instructior ut vim. Usu ad erant maiorum, tollit latine ei ius, ea eos 
 vitae nominati iracundia. Consul laboramus eam ad, eu est nisl expetendis 
 philosophia. Doctus ceteros eu per, ut vel fierent similique accommodare, 
 ius similique consectetuer et.
 Te nec vero quas utamur, in possim nonumes inimicus his, an animal recusabo 
 per. Eos ut natum bonorum legimus. Nihil liberavisse no usu. Sea dignissim 
 mnesarchum cu, et per simul persius, constituto definitionem per in. No vix 
 novum verear apeirian, aliquam accumsan definitionem mel at. Mea et autem 
 phaedrum iracundia, reque vidisse at usu.
 Ad mea commodo oportere. Quo ad debitis accusata atomorum. His dicit 
 labores et, in dicat dolorum abhorreant est, ex qui voluptua oportere. Eum 
 ex nonumy cotidieque signiferumque. Laudem commodo omittantur quo in, voluptua 
 reformidans nam ad, ignota dicunt sed an. Mei ad sonet nonumes, no sit detracto 
 officiis.
 Cibo exerci duo eu. Has habeo atomorum disputationi te, ne has idque delicata. 
 Cibo nihil euismod qui ut. Dicit ubique maiorum duo et, eam ad probo percipit 
 sententiae. Quas lucilius vis ne. Id nec fabellas consetetur, sit id melius 
 impetus cotidieque, eum fierent praesent rationibus id. Qui et liber offendit 
 verterem, ad eripuit eruditi qui.
 Vis affert instructior cu, cum id principes adolescens. Per omnes nominati 
 salutatus at, ne audiam noluisse mel, aeque docendi fierent pro ne. At putant 
 voluptua vis, duo ne etiam tritani. Ut solet laudem qualisque usu, dicunt 
 adipisci his cu. Ea labore convenire corrumpit nec. Ne est quando virtute, 
 virtute adipiscing an ius, an mei iracundia posidonium

    </body> </html>";

        _webView = new WebView
        {
            Source = body,
            VerticalOptions = LayoutOptions.FillAndExpand,
            HorizontalOptions = LayoutOptions.FillAndExpand,
            WidthRequest = App.ScreenWidth * 0.8,
            HeightRequest = 500
        };


        _webView.IsEnabled = false;


        #region Buttons
        Button okButton = new Button();
        okButton.SetWhiteButton();
        okButton.Text = "I ACCEPT";
        okButton.FontSize = Device.GetNamedSize(NamedSize.Large, typeof(Label)) - 5;
        okButton.WidthRequest = Device.GetNamedSize(NamedSize.Large, typeof(Button)) * 5;
        okButton.BorderRadius = Constants.BorderRadius + 5;

        Button cancelButton = new Button();
        cancelButton.SetDefaultButton();
        cancelButton.Text = "CANCEL";
        cancelButton.FontSize = Device.GetNamedSize(NamedSize.Large, typeof(Label)) - 5;
        cancelButton.WidthRequest = Device.GetNamedSize(NamedSize.Large, typeof(Button)) * 5;
        cancelButton.BorderRadius = Constants.BorderRadius + 5;

        bool isChekedTaC = false;
        okButton.Clicked += (s, e) =>
        {
            isChekedTaC = true;
            Navigation.PushAsync(new RegisterOnePageNew(isChekedTaC, registrationRequestModel, "1234"));
        };

       #endregion

        //var a = _webView.Eval("window.onscroll = function(ev) { if ((window.innerHeight + window.pageYOffset) >= document.body.offsetHeight){alert('youre on the bottom');}};"

        //_webView.Navigated += (o, s) => {
        //    _webView.Eval("alert('text')");
        //};
        buttonStack.Children.Add(cancelButton);
        buttonStack.Children.Add(okButton);
        buttonStack.HorizontalOptions = LayoutOptions.CenterAndExpand;
        buttonStack.VerticalOptions = LayoutOptions.Start;

        grid.Children.Add(_webView, 0, 0);
        //grid.Children.Add(buttonStack, 1, 0);


        StackLayout sl = new StackLayout();
        //sl.Children.Add(contentLabel);
        sl.Children.Add(_webView);
        sl.Children.Add(buttonStack);

        mainStackLayout.Children.Add(captionLabel);
        mainStackLayout.Children.Add(new ScrollView { Content = sl });
        //mainStackLayout.Children.Add(buttonStack);
        f.Content = mainStackLayout;
        motherStack.Children.Add(f);
        Content = sl;

    }



    protected override bool OnBackButtonPressed()
    {
        Navigation.PopAsync();
        return true;
    }

当 HTML WebView 到达底部时,我只想显示两个按钮。我怎样才能做到这一点?

#选项 1:在底部时返回 true/false 我成功地使用 XLabs HybridWebView 做到了一半。这是代码,也许对某人有用。

public class HybridView : ContentPage
{
    HybridWebView hybrid;
    public HybridView()
    {
        var stack = new StackLayout
        {
            HorizontalOptions = LayoutOptions.FillAndExpand,
            VerticalOptions = LayoutOptions.FillAndExpand,
            BackgroundColor = Color.White
        };

        var body = new HtmlWebViewSource();
        body.Html = @"<html><body>
                        Lorem ipsum dolor sit amet, utinam tritani interpretaris mel ei, perfecto instructior ut vim. Usu ad erant maiorum, tollit latine ei ius, ea eos vitae nominati iracundia. Consul laboramus eam ad, eu est nisl expetendis philosophia. Doctus ceteros eu per, ut vel fierent similique accommodare, ius similique consectetuer et.
                        Te nec vero quas utamur, in possim nonumes inimicus his, an animal recusabo per. Eos ut natum bonorum legimus. Nihil liberavisse no usu. Sea dignissim mnesarchum cu, et per simul persius, constituto definitionem per in. No vix novum verear apeirian, aliquam accumsan definitionem mel at. Mea et autem phaedrum iracundia, reque vidisse at usu.
                        Ad mea commodo oportere. Quo ad debitis accusata atomorum. His dicit labores et, in dicat dolorum abhorreant est, ex qui voluptua oportere. Eum ex nonumy cotidieque signiferumque. Laudem commodo omittantur quo in, voluptua reformidans nam ad, ignota dicunt sed an. Mei ad sonet nonumes, no sit detracto officiis.
                        Cibo exerci duo eu. Has habeo atomorum disputationi te, ne has idque delicata. Cibo nihil euismod qui ut. Dicit ubique maiorum duo et, eam ad probo percipit sententiae. Quas lucilius vis ne. Id nec fabellas consetetur, sit id melius impetus cotidieque, eum fierent praesent rationibus id. Qui et liber offendit verterem, ad eripuit eruditi qui.
                        Vis affert instructior cu, cum id principes adolescens. Per omnes nominati salutatus at, ne audiam noluisse mel, aeque docendi fierent pro ne. At putant voluptua vis, duo ne etiam tritani. Ut solet laudem qualisque usu, dicunt adipisci his cu. Ea labore convenire corrumpit nec. Ne est quando virtute, virtute adipiscing an ius, an mei iracundia posidonium.
                      </body> </html>";


        hybrid = new HybridWebView
        {
            HorizontalOptions = LayoutOptions.FillAndExpand,
            VerticalOptions = LayoutOptions.FillAndExpand,
            BackgroundColor = Color.White,
            WidthRequest = 300,
            HeightRequest = 600,
            Source = body

        };

        stack.Children.Add(hybrid);

        Content = stack;
    }

    protected override void OnAppearing()
    {
        base.OnAppearing();
        hybrid.InjectJavaScript("window.onscroll = function(ev) { if ((window.innerHeight + window.pageYOffset) >= document.body.offsetHeight){alert('youre on the bottom');}};");
    }
}

现在我必须弄清楚如何从 js 获取 xamarin 表单的信息

最佳答案

您可以将“我同意”和“取消”按钮放入 HTML 中,然后注入(inject)到您的旧源代码中。这样就可以用单个WebView来显示全部了。

关于javascript - termsAndCONditions 使用 WebView 和按钮滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45127738/

相关文章:

javascript - 尝试使用 jquery cycle 插件和 lightbox 插件时发生冲突

android - webview滚动问题android

c# - 如何检查值类型的值是否为 IntPtr.Zero

asynchronous - 在 Xamarin Forms 中下载带有进度条的文件

javascript - 通过跨域 JavaScript 调用防止 CSRF

javascript - 从 jsonp fetch promise 获取 json

javascript从for循环创建数组

html - devtools 中的 CSS webkit-sticky 属性无效

android - Swift:WKWebView 添加像 Android 一样的 javascript 界面

tabs - Xamarin.Android 的底部选项卡(在 Xamarin.forms 应用程序中)