我一直在尝试从iOS上Xamarin表单的JS代码调用操作。一旦我点击代码js就不会被调用。这是我一直在测试的一个例子。一旦我点击了文本,但功能没有被触发,我不想在点击按钮后显示动作,而是在我点击文本后显示。请告诉我我做错了什么。

 <StackLayout x:Name="slHybridView" >
                </StackLayout>


    public MainPage()
    {
        InitializeComponent();
        BindingContext = new LearningPageViewModel();

        ((LearningPageViewModel)BindingContext).TextChanged += TextChanged;
        hybridWebView = new HybridWebView()
        {
            HorizontalOptions = LayoutOptions.FillAndExpand,
            VerticalOptions = LayoutOptions.FillAndExpand,
            Content = ((LearningPageViewModel)BindingContext).ArticleHtmlFormat,
        };
        hybridWebView.RegisterAction(data => DisplayAlert("Alert", "Hello " + data, "OK"));
        slHybridView.Children.Clear();
        slHybridView.Children.Add(hybridWebView);

    }

        public class HybridWebViewRenderer : WkWebViewRenderer, IWKScriptMessageHandler
        {
            const string JavaScriptFunction = "function invokeCSharpAction(data){window.webkit.messageHandlers.invokeAction.postMessage(data);}";
            WKUserContentController userController;
    
    
            public HybridWebViewRenderer()
            {
            }
    
            public HybridWebViewRenderer(WKWebViewConfiguration config) : base(config)
            {
                userController = config.UserContentController;
                var script = new WKUserScript(new NSString(JavaScriptFunction), WKUserScriptInjectionTime.AtDocumentEnd, false);
                userController.AddUserScript(script);
                userController.AddScriptMessageHandler(this, "invokeAction");
            }
    
            protected override void OnElementChanged(VisualElementChangedEventArgs e)
            {
                base.OnElementChanged(e);
    
                if (e.OldElement != null)
                {
                    userController.RemoveAllUserScripts();
                    userController.RemoveScriptMessageHandler("invokeAction");
                    HybridWebView hybridWebView = e.OldElement as HybridWebView;
                    hybridWebView.Cleanup();
                }
    
                if (e.NewElement != null)
                {
                    var html = string.Empty;
                    var iOSHtmlWithScaling = html.Insert(0, "<meta name='viewport' content='width=device-width,initial-scale=1,maximum-scale=1' />");
                    var script = new WKUserScript(new NSString(JavaScriptFunction), WKUserScriptInjectionTime.AtDocumentEnd, false);
                    Configuration.UserContentController.AddUserScript(script);
                    Configuration.UserContentController.AddScriptMessageHandler(this, JavaScriptFunction);
                    LoadData(((HybridWebView)Element).Content, iOSHtmlWithScaling, "utf-8", new NSUrl(""));
                }
            }
    
            public void DidReceiveScriptMessage(WKUserContentController userContentController, WKScriptMessage message)
            {
                ((HybridWebView)Element).InvokeAction(message.Body.ToString());
            }
    
            protected override void Dispose(bool disposing)
            {
                if (disposing)
                {
                    ((HybridWebView)Element).Cleanup();
                }
                base.Dispose(disposing);
            }
         
        }
    
      public LearningPageViewModel()
            {
                articleHtmlFormat = ArticleHtml();
            }
            
            public string ArticleHtml()
            {
               var articleHtml = @"<html>
    <head>
      <meta name='viewport' content='width=device-width,initial-scale=1,maximum-scale=1' />
    </head>
    <body class='avat'>
        <style>
        
    .avat {
        font-family: sans-serif;
        font-size: 15px;
        text-align: justify;
    }
    
    .title {
        font-size: 16px;
    }
    
    .red {
      color: red;
    }
    
    .word {
      font-weight: bold;
    }
    .phrase {
      text-decoration: underline;
    }
        </style>
        <script type='text/javascript'>
                   function invokeCSCode(data) {
                
               var els = document.getElementsByClassName('red');
                 while (els[0]) {
                    els[0].classList.remove('red');
                  }
    
                invokeCSharpAction(data);
                var my_element = document.querySelector('[sentenceId=' + data + ']');
                 my_element.scrollIntoView({
                                behavior: 'smooth',
                    block: 'center',
                    inline: 'nearest'
                              });
    
                var sentenceName = my_element.getAttribute('sentenceName');
    
                if (data[0] === 's')
                {
                    var x = document.querySelectorAll('[sentenceName=' + sentenceName + ']');
                    var i;
                    for (i = 0; i < x.length; i++)
                    {
                        x[i].classList.add('red');
                    }
                }
                else
                {
                    my_element.classList.add('red');
                }
    
            }
    
    function scrollToPosition(data) {
                
                var els = document.getElementsByClassName('red');
                 while (els[0]) {
                    els[0].classList.remove('red');
                  }
    
                var my_element = document.querySelector('[sentenceId=' + data + ']');
                 my_element.scrollIntoView({
                                behavior: 'smooth',
                    block: 'center',
                    inline: 'nearest'
                              });
    
                var sentenceName = my_element.getAttribute('sentenceName');
    
                if (data[0] === 's')
                {
                    var x = document.querySelectorAll('[sentenceName=' + sentenceName + ']');
                    var i;
                    for (i = 0; i < x.length; i++)
                    {
                        x[i].classList.add('red');
                    }
                }
                else
                {
                    my_element.classList.add('red');
                }
    
            }
        </script>
     ";
    
    
                 var spans = FindAllClickableSpans(Article()).ToArray();
    
                 for (int i = 0; i < spans.Length; i++)
                 {
                     articleHtml += "<span ";
                     articleHtml += " sentenceId='" + i + "' onclick='javascript: invokeCSCode(\"" + i + "\");' sentenceName='" + i + "'>" + spans[i] + "</span>";
                 }

                articleHtmlFormat = articleHtml;
                 
                 return articleHtmlFormat;
            }
    
            public string Article()
            {
               return @"Excuse me,” said a girl, “you look lost. Can I help you?”\“Yes, please. Thank you.";
            }
            
            private IEnumerable<string> FindAllClickableSpans(string article)
            {
                article = article.ToLower();
    
                return article.Split('.');
                
            }

JS webView Xamariforms的更多相关文章

  1. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  2. HTML5数字输入仅接受整数的实现代码

    这篇文章主要介绍了HTML5数字输入仅接受整数的实现代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. amaze ui 的使用详细教程

    这篇文章主要介绍了amaze ui 的使用详细教程,本文通过多种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  4. html5简介_动力节点Java学院整理

    这篇文章主要介绍了html5简介,用于指定构建网页的元素,这些元素中的大多数都用于描述网页内容,有兴趣的可以了解一下

  5. ios 8 Homescreen webapp,关闭和打开iPad停止javascript

    我有一个适用于iPad的全屏HTML5网络应用程序,并且刚刚安装了IOS8来试用它,它一切正常,直到你关闭并重新启动iPad.一旦web应用程序重新启动javascript就会停止并加载新页面不会重新启动它.在iPad上的Safari中打开同一页面时,关闭和打开iPad会继续按预期工作.其他人注意到了这个或想出了一个解决方案吗?解决方法这似乎是我在iOS8.1.1更新中解决的.

  6. iOS 6 javascript与object.defineProperty的间歇性问题

    当访问使用较新的Object.defineProperty语法定义属性的对象的属性时,有没有其他人注意到新iOS6javascript引擎中的间歇性错误/问题?https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Object/defineProperty我正在看到javascript失败的情况,说

  7. ios – 如何使用JSExport导出内部类的方法

    解决方法似乎没有办法将内部类函数导出到javascript.我将内部类移出并创建了独立的类,它起作用了.

  8. 静音iOS推送通知与React Native应用程序在后台

    我有一个ReactNative应用程序,我试图获得一个发送到JavaScript处理程序的静默iOS推送通知.我看到的行为是AppDelegate中的didReceiveRemoteNotification函数被调用,但是我的JavaScript中的处理程序不会被调用,除非应用程序在前台,或者最近才被关闭.我很困惑的事情显然是应用程序正在被唤醒,并且它的didReceiveRemoteNotifi

  9. ios – 内存泄漏与UIWebView和Javascript

    清楚地包含一个Javascript文件到我的HTML是使UIWebView泄漏内存.当我重复使用相同的UIWebView对象时,或者每当我有内容实例化一个新的漏洞时,会出现泄漏的事实,导致我认为必须有一些JavaScript文件被loadHTMLString处理,导致泄漏.有人知道如何解决这个问题吗?

  10. iOS应用程序的UI自动化测试如何与乐器和Javascript

    从WWDC2010视频会议中了解iOS应用程序的自动化UI测试,但没有实践.从代码项目project,我们可以有一个例子.这个问题在这里听到有涉及这个的人.任何限制?解决方法我建议从AlexWollmer开始使用thisblogpost.他创建了一个非常有用的JavaScript库:tuneup_jswithtest()函数,它允许测试分离和有用的帮助者以及为自动化仪器编写测试的断言.

随机推荐

  1. 如何扩展ATmega324PB微控制器的以下宏寄存器?

    我目前正在学习嵌入式,我有以下练习:展开以下宏寄存器:如果有人解决了这个问题,我将不胜感激,以便将来参考

  2. Python将ONNX运行时设置为返回张量而不是numpy数组

    在python中,我正在加载预定义的模型:然后我加载一些数据并运行它:到目前为止,它仍在正常工作,但我希望它默认返回Tensor列表,而不是numpy数组。我对ONNX和PyTorch都是新手,我觉得这是我在这里缺少的基本内容。这将使转换中的一些开销相同。

  3. 在macOS上的终端中使用Shell查找文件中的单词

    我有一个文本文件,其中有一行:我需要找到ID并将其提取到变量中。我想出了一个RexEx模式:但它似乎对我尝试过的任何东西都不起作用:grep、sed——不管怎样。我的一个尝试是:我为这样一个看似愚蠢的问题感到抱歉,但我在互联网上找不到任何东西:我在SO和SE上读了几十个类似的问题,并在谷歌上搜索了几个教程,但仍然无法找到答案。欢迎提供任何指导!

  4. react-chartjs-2甜甜圈图中只有标题未更新

    我正在使用react-chartjs-2在我的网站中实现甜甜圈图。下面是我用来呈现图表的代码。我将甜甜圈图的详细信息从父组件传递到子组件,所有道具都正确传递。当我在beforeDraw函数外部记录props.title时,它会记录正确的值,但当我在beforeDraw函数内部记录props.title时,它将记录标题的前一个值,从而呈现标题的前值。我在这里做错了什么?

  5. 如何在tkinter中使用Python生成器函数?

    生成器函数承诺使某些代码更易于编写。但我并不总是知道如何使用它们。假设我有一个斐波那契生成器函数fib(),我想要一个显示第一个结果的tkinter应用程序。当我点击“下一步”按钮时,它会显示第二个数字,依此类推。我如何构建应用程序来实现这一点?我可能需要在线程中运行生成器。但如何将其连接回GUI?

  6. 如何为每次提交将存储库历史记录拆分为一行?

    我正在尝试获取存储库的历史记录,但结果仅以单行文本的形式返回给我。

  7. 尝试在颤振项目上初始化Firebase时出错

    当尝试在我的颤振项目上初始化firebase时,我收到了这个错误有人知道我能做什么吗?应用程序分级Gradle插件Gradle项目颤振相关性我已经将firebase设置为Google文档已经在另一个模拟器上尝试过,已经尝试过创建一个全新的模拟器,已经在不同的设备上尝试过了,已经尝试了特定版本的firebase,已经尝试添加但没有任何效果,已经在youtube上看到了关于它的每一个视频,该应用程序在android和iOS两个平台上都抛出了这个错误

  8. 在unix中基于当前日期添加新列

    我试图在unix中基于时间戳列在最后一个单元格中添加一个状态列。我不确定如何继续。

  9. 麦克斯·蒙特利。我一直得到UncaughtReferenceError:当我在终端中写入node-v时,节点未定义

    如果这是您应该知道的,请确认:我已将所有shell更改为默认为zsh。当我在终端中写入node-v时,我一直收到“UncaughtReferenceError:nodeisnotdefined”。但它显示节点已安装。我是个新手,在这方面经验不足。

  10. 如何在前端单击按钮时调用后端中的函数?

    那么如何在后端添加一个新的端点,点击按钮调用这个函数。

返回
顶部